千家信息网

Flutter中的数据库怎么使用

发表于:2025-01-16 作者:千家信息网编辑
千家信息网最后更新 2025年01月16日,这篇文章主要讲解了"Flutter中的数据库怎么使用",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"Flutter中的数据库怎么使用"吧!在Flutte
千家信息网最后更新 2025年01月16日Flutter中的数据库怎么使用

这篇文章主要讲解了"Flutter中的数据库怎么使用",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"Flutter中的数据库怎么使用"吧!

在Flutter开发过程中,我门有时候需要对一些数据进行本地的持久化存储,使用sp文件形式虽然也能解决问题,但是有时数据量较大的时候,显然我们文件形式就不太合适了,这时候我们就需要使用数据库进行存储,我们知道在原生中有系统提供的轻量级sqlite数据库,在Flutter强大的生态环境中,也有这样一个数据库插件sqflite: ^2.0.2可以同时在Androud、iOS中进行数据库操作。

1、 创建数据库:这里我以存储我的搜索历史记录为例

首先导入:

import 'package:sqflite/sqflite.dart';

这里我创建了一个数据库帮助类,为了以后数据库更新、升级等作准备:

代码实现:主要是对Database这个类的获取进行了封装。

/// 数据库帮助类class DbHelper {  final String path = "laoli.db"; // 数据库名称 一般不变 //数据库中的表名字 这里是我存错历史搜索记录的表  static final searchTab = "SearchHistory";   //私有构造  DbHelper._();  static DbHelper? _instance;  static DbHelper get instance => _getInstance();  factory DbHelper() {    return instance;  }  static DbHelper _getInstance() {    if (_instance == null) {      _instance = DbHelper._();    }    return _instance ?? DbHelper._();  }/// 数据库默认存储的路径  /// SQLite 数据库是文件系统中由路径标识的文件。如果是relative,  /// 这个路径是相对于 获取的路径getDatabasesPath(),  /// Android默认的数据库目录,  /// iOS/MacOS的documents目录。  Future? _db;  Future? getDb() {    _db ??= _initDb();    return _db;  }  // Guaranteed to be called only once.保证只调用一次  Future _initDb() async {  // 这里是我们真正创建数据库的地方 vserion代表数据库的版本,如果版本改变  //,则db会调用onUpgrade方法进行更新操作    final db =        await openDatabase(this.path, version: 1, onCreate: (db, version) {      // 数据库创建完成      // 创建表 一个自增id 一个textdb.execute("create table $searchTab (id integer primary key autoincrement, name text not null)");          }, onUpgrade: (db, oldV, newV) {      // 升级数据库调用     ///  db 数据库   ///   oldV 旧版本号   //   newV 新版本号   //   升级完成就不会在调用这个方法了    });return db;  }// 关闭数据库  close() async {    await _db?.then((value) => value.close());  }}

java后台开发过程中,数据库肯定都会分层设计,这样的好处可以在使用的过程中极大的提高代码的健壮性以及降低后期的维护成本,在移动前端虽然我们用数据库的地方跟后台相比少之又少,但是我还是建议也对数据库进行分层处理操作,虽然不分层也能实现,但是这样也可以降低我们的对于代码的维护成本以及良好的编程习惯。废话不多说,接下来我们需要创建处理数据的dao层。

这里sqflite封装了一些常用的sql语法,比如增删改查,我们就不需要自己去写sql语法了,这里我简答封装了下增删改查的方法。

具体代码:

/// 数据操作类class DbSearchHistoryDao {  /// 增  static insert(String text) {    // 去重    queryAll().then((value) {      bool isAdd = true;      for (var data in value) {        if (data.name == text) {          isAdd = false;          break;        }      }      if (isAdd) {        DbHelper.instance.getDb()?.then((value) => value.insert(              DbHelper.searchTab,              DbSearchHotBean(name: text).toJson(),            ));      }    });  }  /// 删 全部  static deleteAll() {    DbHelper.instance.getDb()?.then((value) => value.delete(          DbHelper.searchTab,        ));  }  /// 更新数据 通过id更新表内具体行的数据  static update(DbSearchHotBean dbSearchHotBean) {    DbHelper.instance.getDb()?.then((value) => value.update(      DbHelper.searchTab,      dbSearchHotBean.toJson(),//具体更新的数据      where: "id = ?"//通过id查找需要更新的数据      ,whereArgs: [dbSearchHotBean.id]    ));  }  /// 通过name查具体的实体类  static Future getBean(String name) async {  var db = await DbHelper.instance.getDb();  var maps = await db?.query(DbHelper.searchTab,    columns: ['id','name'],// 获取实体类的哪些字段 默认全部    where: 'name = ?',//通过实体类中的name字段    whereArgs: [name]);//具体name的值 限定数据  if(maps!=null && maps.length > 0) {       return DbSearchHotBean.fromJson(maps.first);  }  return null;  }  /// 查 全部all  static Future> queryAll() async {    List list = [];    await DbHelper.instance        .getDb()        ?.then((db) => db.query(DbHelper.searchTab).then((value) {              for (var data in value) {                list.add(DbSearchHotBean.fromJson(data));              }            }));    return list;  }}

实体类:虽然只有一个字段,但是创建实体类方便以后扩展。

class DbSearchHotBean {  int? id;  String? name; // 搜索词  DbSearchHotBean({this.id,required this.name});  DbSearchHotBean.fromJson(Map json) {    id = json['id'];    name = json['name'];  }  Map toJson() {    var map = {};    map['id'] = id?.toString() ;    map['name'] = name ?? "";    return map;  }}

具体用法就非常简单了

增:DbSearchHistoryDao.insert("搜索词");

删全部:DbSearchHistoryDao.deleteAll();

改:例如将水改为火, 找到水的实体通过自增id修改name

DbSearchHistoryDao.getBean("水").then((value){  if(value!=null){    DbSearchHistoryDao.update(DbSearchHotBean(id: value.id,name: "火"));  }});

查全部:await DbSearchHistoryDao.queryAll();

到这里数据库的基本用法就介绍完了,当然部分操作比如删指定数据,批量修改、批量删除等操作可以用 到批处理操作,这里就不过多介绍了,有需要的可以查看作者文档。链接

batch = db.batch();batch.insert('Test', {'name': 'item'});batch.update('Test', {'name': 'new_item'}, where: 'name = ?', whereArgs: ['item']);batch.delete('Test', where: 'name = ?', whereArgs: ['item']);results = await batch.commit();

感谢各位的阅读,以上就是"Flutter中的数据库怎么使用"的内容了,经过本文的学习后,相信大家对Flutter中的数据库怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

数据 数据库 实体 更新 代码 文件 路径 存储 搜索 字段 方法 版本 过程 升级 学习 封装 内容 历史 后台 地方 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 西安智园软件开发 山东盈诚互联网科技有限公司 魅族的VPN服务器地址 南京网络营销软件开发哪个好 当今数据库操作的通用语言 青岛小鱼网络技术怎么样 我的世界服务器购买领地指令 港中升网络技术深圳有限公司 五轴激光编程cam软件开发公司 服务器地址类型如何判断 数据库优化如何应对百万并发 星云数据库 上海朱璐网络安全员 软件开发属于前端还是后端输出物 黔东南web服务器cpu xp虚拟服务器 时空信息城市大数据库 信息技术处理员数据库 战神级的互联网科技圈大佬们 国家级网络安全工程师证书 万方数据库人工客服 流媒体服务器搭建的方法 湖北通信软件开发过程检测中心 设计数据库 考虑效率 租的服务器怎么下载东西 数据库的修改实验截图 邯郸办公系统软件开发多少钱 关于网络安全作文 大湾区网络安全科技 服务器显示驱动器找不到
0