在鸿蒙平台使用 sqlite3 插件

插件介绍

fluttertpc_sqlite3 是一个 Flutter 插件,用于在鸿蒙平台上使用 SQLite 数据库。SQLite 是一个轻量级的嵌入式数据库,广泛应用于移动设备和桌面应用中。该插件提供了简单易用的 API 来进行数据库的创建、查询、插入、更新和删除操作。

主要功能包括:

  1. 数据库管理:可以创建、打开和关闭 SQLite 数据库
  2. 数据操作:支持 SQL 查询、插入、更新和删除操作
  3. 事务处理:支持事务操作,确保数据的一致性
  4. 异步操作:所有数据库操作都支持异步执行,不会阻塞 UI 线程
  5. 鸿蒙适配:专门针对鸿蒙平台进行了优化和适配

安装与使用

1. 安装方式

在项目的 pubspec.yaml 文件中添加以下依赖配置:

yaml 复制代码
dependencies:
  fluttertpc_sqlite3:
    git:
      url: "https://atomgit.com/fluttertpc/fluttertpc_sqlite3.git"

执行命令安装依赖:

bash 复制代码
flutter pub get

2. 基本使用示例

2.1 打开数据库
dart 复制代码
import 'package:fluttertpc_sqlite3/sqlite3.dart';

Future<void> openDatabase() async {
  final db = await SQLite3.openDatabase('test.db');
  print('Database opened successfully');
}
2.2 创建表
dart 复制代码
Future<void> createTable() async {
  final db = await SQLite3.openDatabase('test.db');
  await db.execute('''
    CREATE TABLE IF NOT EXISTS users (
      id INTEGER PRIMARY KEY AUTOINCREMENT,
      name TEXT NOT NULL,
      email TEXT NOT NULL UNIQUE
    )
  ''');
  print('Table created successfully');
}
2.3 插入数据
dart 复制代码
Future<void> insertData() async {
  final db = await SQLite3.openDatabase('test.db');
  await db.execute('''
    INSERT INTO users (name, email) VALUES ('John Doe', 'john@example.com')
  ''');
  print('Data inserted successfully');
}
2.4 查询数据
dart 复制代码
Future<void> queryData() async {
  final db = await SQLite3.openDatabase('test.db');
  final result = await db.query('SELECT * FROM users');
  for (final row in result) {
    print('User: ${row['name']} (${row['email']})');
  }
}
2.5 更新数据
dart 复制代码
Future<void> updateData() async {
  final db = await SQLite3.openDatabase('test.db');
  await db.execute('''
    UPDATE users SET name = 'John Smith' WHERE email = 'john@example.com'
  ''');
  print('Data updated successfully');
}
2.6 删除数据
dart 复制代码
Future<void> deleteData() async {
  final db = await SQLite3.openDatabase('test.db');
  await db.execute('''
    DELETE FROM users WHERE email = 'john@example.com'
  ''');
  print('Data deleted successfully');
}
2.7 事务处理
dart 复制代码
Future<void> transactionExample() async {
  final db = await SQLite3.openDatabase('test.db');
  await db.transaction((txn) async {
    await txn.execute('''
      INSERT INTO users (name, email) VALUES ('Alice', 'alice@example.com')
    ''');
    await txn.execute('''
      INSERT INTO users (name, email) VALUES ('Bob', 'bob@example.com')
    ''');
  });
  print('Transaction completed successfully');
}

3. 核心 API 说明

方法名 功能描述 参数说明 返回值类型
openDatabase(String path) 打开或创建数据库 path:数据库文件路径 Future
execute(String sql) 执行 SQL 语句 sql:要执行的 SQL 语句 Future
query(String sql) 执行查询语句 sql:要执行的查询语句 Future<List<Map<String, dynamic>>>
transaction(Future Function(Transaction) action) 执行事务操作 action:事务回调函数 Future
close() 关闭数据库 / Future

约束与限制

兼容性

该插件已在鸿蒙平台上进行了适配和测试,支持以下环境:

  • Flutter: 3.7.12-ohos-1.0.6; SDK: 5.0.0(12); IDE: DevEco Studio: 5.0.13.200; ROM: 5.1.0.120 SP3;
  • Flutter: 3.22.1-ohos-1.0.1; SDK: 5.0.0(12); IDE: DevEco Studio: 5.0.13.200; ROM: 5.1.0.120 SP3;

总结

fluttertpc_sqlite3 插件为鸿蒙平台提供了一个简单易用的 SQLite 数据库操作接口,支持常见的数据库操作和事务处理。通过该插件,开发者可以轻松地在 Flutter 应用中实现数据的持久化存储,适用于各种需要本地数据存储的场景。

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net

相关推荐
编程乐学1 天前
鸿蒙非原创--DevEcoStudio开发的奶茶点餐APP
华为·harmonyos·deveco studio·鸿蒙开发·奶茶点餐·鸿蒙大作业
鸣弦artha1 天前
Flutter框架跨平台鸿蒙开发 —— Text Widget:文本展示的艺术
flutter·华为·harmonyos
lili-felicity1 天前
React Native for Harmony:Rating 评分组件- 支持全星 / 半星 / 禁用 / 自定义样式
react native·华为·harmonyos
grd41 天前
RN for OpenHarmony 小工具 App 实战:屏幕尺子实现
笔记·harmonyos
No Silver Bullet1 天前
HarmonyOS NEXT开发进阶(十九):如何在 DevEco Studio 中查看已安装应用的运行日志
华为·harmonyos
大雷神1 天前
HarmonyOS智慧农业管理应用开发教程--高高种地
华为·harmonyos
南村群童欺我老无力.1 天前
Flutter 框架跨平台鸿蒙开发 - 开发双人对战五子棋游戏
flutter·游戏·华为·typescript·harmonyos
夜雨声烦丿1 天前
Flutter 框架跨平台鸿蒙开发 - 消消乐游戏开发教程
flutter·游戏·华为·harmonyos
数通工程师1 天前
IPv4和IPv6 地址分配:从划分到工具全解析
网络·网络协议·tcp/ip·华为
夜雨声烦丿1 天前
Flutter 框架跨平台鸿蒙开发 - 数独求解器开发教程
flutter·游戏·华为·harmonyos