Flutter 26: 图解关乎 SQL 数据库的二三事 (一)

简介: 0 基础学习 Flutter:第二十六步:学习了解 SQL 的基本操作~

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

集成方式

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

SQL 操作

1. 创建数据库

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

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 方式相同。

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 方式插入数据表。

// 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 语句进行处理。

// 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 内部已处理好,若数据库表不存在也不会报异常。

// 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 对数据库表进行内容数据更新,可根据需求变更固定字段或整条数据。

// 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 的方法,如果有哪位大神了解请多多指导。注:若用如下方式只会删除当前表中所有数据而不会删除表。

onPressed: () async {
  await db.delete('User');
}

8. 删除数据库

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

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 语句。

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

目录
相关文章
|
1月前
|
SQL 机器学习/深度学习 人工智能
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
本文系统性地阐述了自然语言转SQL(NL2SQL) 技术如何让非技术背景的业务分析师实现数据自助查询,从而提升数据驱动决策的效率与准确性。
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
|
4月前
|
SQL 存储 关系型数据库
第二篇:关系型数据库的核心概念与 SQL 基础
本篇内容深入浅出地讲解了关系型数据库的核心概念与SQL基础,适合有一定计算机基础的学习者。文章涵盖数据库的基本操作(CRUD)、数据类型、表的创建与管理等内容,并通过实例解析SELECT、INSERT、UPDATE、DELETE等语句的用法。此外,还推荐了多种学习资源与实践建议,帮助读者巩固知识。学完后,你将掌握基础数据库操作,为后续高级学习铺平道路。
224 1
|
18天前
|
SQL Oracle 关系型数据库
Oracle数据库创建表空间和索引的SQL语法示例
以上SQL语法提供了一种标准方式去组织Oracle数据库内部结构,并且通过合理使用可以显著改善查询速度及整体性能。需要注意,在实际应用过程当中应该根据具体业务需求、系统资源状况以及预期目标去合理规划并调整参数设置以达到最佳效果。
76 8
|
23天前
|
SQL 人工智能 Java
用 LangChain4j+Ollama 打造 Text-to-SQL AI Agent,数据库想问就问
本文介绍了如何利用AI技术简化SQL查询操作,让不懂技术的用户也能轻松从数据库中获取信息。通过本地部署PostgreSQL数据库和Ollama模型,结合Java代码,实现将自然语言问题自动转换为SQL查询,并将结果以易懂的方式呈现。整个流程简单直观,适合初学者动手实践,同时也展示了AI在数据查询中的潜力与局限。
146 8
|
29天前
|
SQL 人工智能 Linux
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
108 5
|
5月前
|
SQL 数据库 数据安全/隐私保护
数据库数据恢复——sql server数据库被加密的数据恢复案例
SQL server数据库数据故障: SQL server数据库被加密,无法使用。 数据库MDF、LDF、log日志文件名字被篡改。 数据库备份被加密,文件名字被篡改。
|
6天前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
|
3月前
|
SQL 关系型数据库 MySQL
Go语言数据库编程:使用 `database/sql` 与 MySQL/PostgreSQL
Go语言通过`database/sql`标准库提供统一数据库操作接口,支持MySQL、PostgreSQL等多种数据库。本文介绍了驱动安装、连接数据库、基本增删改查操作、预处理语句、事务处理及错误管理等内容,涵盖实际开发中常用的技巧与注意事项,适合快速掌握Go语言数据库编程基础。
263 62
|
2月前
|
SQL 缓存 监控
SqlRest让SQL秒变Http API,还支持20+数据库(含国产数据库)
杭州奥零数据科技有限公司成立于2023年,专注于数据中台业务,维护开源项目AllData并提供商业版解决方案。AllData提供数据集成、存储、开发、治理及BI展示等一站式服务,支持AI大模型应用,助力企业高效利用数据价值。
|
2月前
|
SQL 存储 数据库
SQL Server Management Studio (SSMS) 21 - 微软数据库管理工具
SQL Server Management Studio (SSMS) 21 - 微软数据库管理工具
484 0