前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Flutter 专题】26 图解关于 SQL 数据库的二三事 (一)

【Flutter 专题】26 图解关于 SQL 数据库的二三事 (一)

作者头像
阿策小和尚
发布2019-08-12 16:19:41
9930
发布2019-08-12 16:19:41
举报
文章被收录于专栏:阿策小和尚

和尚刚刚学习一下关于数据存储方面的小知识点,用 sqflite 对数据库进行基本操作。sqflite 为三方 pub 通用的引入方式。和尚仅对数据库的基本操作进行学习整理。

集成方式

  1. pubspec.yaml 中添加 sqflite: any
  2. 在相应的 .dart 文件中添加引用 import 'package:sqflite/sqflite.dart';
  3. 根据需求对数据存储进行具体的 SQL 操作,如下:

SQL 操作

1. 创建数据库

sqflite 创建数据库时优先创建一个路径,用来存储数据库。注:对于数据库的操作都是耗时操作,都要通过 asyncawait 异步处理。

代码语言:javascript
复制
FlatButton(
    color: Colors.blue,
    child: Text('创建一个 flutter_app.db 数据库'),
    onPressed: () async {
      var databasesPath = await getDatabasesPath();
      path = join(databasesPath, 'flutter_app.db');
    }),
2. 创建数据表

借助 db.execute 来创建一张数据表,跟普通的 SQL 方式相同。

代码语言:javascript
复制
FlatButton(
    color: Colors.blue,
    child: Text('创建一张 user 表'),
    onPressed: () async {
      db = await openDatabase(path, version: 1,
          onCreate: (Database db, int version) async {
        await db.execute(
            'CREATE TABLE User (id INTEGER PRIMARY KEY, name TEXT, age INTEGER, address TEXT)');
      });
    }),
3. 【增】插入数据

借助 rawInsertdb.insert 对数据库表数据进行插入。根本上都是通过 insert into 方式插入数据表。

代码语言:javascript
复制
// db.transaction
_transactionOneUser(UserBean userBean) async {
  await db.transaction((txn) async {
    await txn.rawInsert(
        'INSERT INTO User(name, age, address) VALUES(${userBean.name}, '
        '${userBean.age},'
        '${userBean.address}'
        ')');
  });
}

// db.insert
_insertOneUser(var tableName, UserBean userBean) async {
  await db.insert(tableName, userBean.toMap());
}
4. 【查】查询数据

借助 rawQuerydb.select 对数据库表信息进行查询,是操作最灵活对部分,配合各种 SQL 语句进行处理。

代码语言:javascript
复制
// db.rawQuery
Future<List<Map>> _getUserList() async {
  List<Map> list = await db.rawQuery('SELECT * FROM User');
  return list;
}

// db.query
Future<List<Map>> _getUserByName(var tableName, var name) async {
  List<Map> list =
      await db.query(tableName, where: 'name = ?', whereArgs: [name]);
  return list;
}
5. 【删】删除数据

借助 rawDeletedb.delete 对数据库表进行数据删除,和尚测试删除 id = 0和1 的对应数据,sqflite 内部已处理好,若数据库表不存在也不会报异常。

代码语言:javascript
复制
// rawDelete
_deleteRawUserByID(int id) async {
  return await db.transaction((txn) async {
    await txn.rawDelete('DELETE FROM User WHERE id = ${id}');
  });
}

// db.delete
_deleteUserByID(var tableName, int id) async {
  return await db.delete(tableName, where: 'id = ?', whereArgs: [id]);
}
6. 【改】更新数据

借助 rawUpdatedb.update 对数据库表进行内容数据更新,可根据需求变更固定字段或整条数据。

代码语言:javascript
复制
// rawUpdate
_updateRawUser(var userBean) async {
  return await db.transaction((txn) async {
    await txn.rawUpdate('UPDATE User SET address = "${userBean.address}" '
        'WHERE name = "${userBean.name}"');
  });
}

// db.update
Future<int> _updateUser(var tableName, var userBean) async {
  return await db.update(tableName, userBean.toMap(),
      where: 'name = ?', whereArgs: [userBean.name]);
}
7. 删除数据表

和尚刚接触数据库,没有找到直接删除表的方式,没有类似 drop 的方法,如果有哪位大神了解请多多指导。注:若用如下方式只会删除当前表中所有数据而不会删除表。

代码语言:javascript
复制
onPressed: () async {
  await db.delete('User');
}
8. 删除数据库

删除数据库与创建数据库相对应,直接对路径进行操作。

代码语言:javascript
复制
FlatButton(
    color: Colors.blue,
    child: Text('删除数据库', style: TextStyle(color: Colors.white)),
    onPressed: () async {
      await deleteDatabase(path);
    })

注意事项

  1. 建议在对数据库表进行增删改查前优先判断数据库是否存在,可统一封装方法以降低异常;
  2. 对于数据库表的增删改查,和尚使用了两种方式:一种是直接 db.增删改查,另一种是 db.transaction 后对回调 raw+增删改查,两种的区别是,第一种使用更便捷,可直接修改整条数据;第二种使用更灵活,可对部分数据字段进行调整,可以看图例中的【更新】结果;
  3. 在使用 db.transaction 对数据库表进行增删改查时要注意 SQL 语句的完整性,包括传递 String 类型参数时要加引号,执行的是一个完整的 SQL 语句。

数据库的操作灵活多样,和尚刚刚尝试,本篇仅记录一下基本的使用情况,对于更多灵活的方法会继续尝试整理,有问题的地方请大家多多指导。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-12-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 阿策小和尚 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 集成方式
  • SQL 操作
    • 1. 创建数据库
      • 2. 创建数据表
        • 3. 【增】插入数据
          • 4. 【查】查询数据
            • 5. 【删】删除数据
              • 6. 【改】更新数据
                • 7. 删除数据表
                  • 8. 删除数据库
                  • 注意事项
                  相关产品与服务
                  对象存储
                  对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档