Flutter中sqflite的使用案例

目录

引言

安装sqflite

创建表

查询数据

添加数据

删除数据

更新数据

完整使用案例


引言

随着移动应用的发展,本地数据存储成为了一个不可或缺的功能。在Flutter中,sqflite 是一个非常流行且强大的SQLite插件,它允许开发者在移动设备上轻松地进行数据库操作。本文将通过具体的使用案例,详细介绍如何在Flutter项目中集成和使用 **sqflite**进行数据存储和查询。

安装sqflite

首先,你需要在**pubspec.yaml** 文件中添加**sqflite**依赖:

Dart 复制代码
dependencies:
  flutter:
    sdk: flutter
  sqflite: ^2.3.3+1

然后运行 flutter pub get 来安装依赖,或者直接执行下面的命令

flutter pub add sqflite

创建表

Dart 复制代码
// 创建表
  Future<void> _onCreate(Database db, int version) async {
    await db.execute('''
      CREATE TABLE Domain (
        id INTEGER PRIMARY KEY AUTOINCREMENT,
        url TEXT
      )
    ''');
  }

查询数据

Dart 复制代码
// 查看表的数据
  Future<List<Map<String, dynamic>>> getItemsFromTable() async {
    Database db = await database;
    return await db.query("Domain");
  }
// 查看存在某一条数据
 Future<bool> checkIfQrExists(String url) async {
    Database db = await database;
    List<Map<String, dynamic>> results = await db.query(
      'Domain',
      where: 'url= ?',
      whereArgs: [url],
    );
    return results.isNotEmpty;
  }

添加数据

Dart 复制代码
Future<void> insertDomain(String url) async {
    Database db = await database;
    await db.insert('Domain', {
      'url': url,
    });
  }

删除数据

Dart 复制代码
Future<void> deleteUrl(String url) async {
  final db = await database;
  await db.delete(
    'Domain',
    where: 'url = ?',
    whereArgs: [url],
  );
}

更新数据

Dart 复制代码
Future<void> updateUrl(Map<String, dynamic> domain, String url) async {
  final db = await database;
  await db.update(
    'Domain',
    domain,
    where: 'url = ?',
    whereArgs: [url],
  );
}

完整使用案例

Dart 复制代码
import 'package:sqflite/sqflite.dart';
import 'package:path/path.dart';

class DatabaseHelper {
  static final DatabaseHelper _instance = DatabaseHelper._internal();
  factory DatabaseHelper() => _instance;
  static Database? _database;
  static const int databaseVersion = 2;

  DatabaseHelper._internal();

  Future<Database> get database async {
    if (_database != null) return _database!;
    _database = await _initDatabase();
    return _database!;
  }

  Future<Database> _initDatabase() async {
    // 初始化操作
    String path = join(await getDatabasesPath(), 'app_database.db');
    return await openDatabase(
      path,
      version: databaseVersion,
      onCreate: _onCreate,
      onUpgrade: _onUpgrade,
    );
  }

  // 创建表
  Future<void> _onCreate(Database db, int version) async {
    await db.execute('''
      CREATE TABLE Domain (
        id INTEGER PRIMARY KEY AUTOINCREMENT,
        url TEXT
      )
    ''');
  }

  Future<void> _onUpgrade(Database db, int oldVersion, int newVersion) async {
    print("版本号为$oldVersion");
    if (oldVersion < 2) {
      // 更新数据库的操作
    }
  }

  // 查看表的数据
  Future<List<Map<String, dynamic>>> getItemsFromTable() async {
    Database db = await database;
    return await db.query("Domain");
  }

// 查看存在某一条数据
  Future<bool> checkIfQrExists(String url) async {
    Database db = await database;
    List<Map<String, dynamic>> results = await db.query(
      'Domain',
      where: 'url= ?',
      whereArgs: [url],
    );
    return results.isNotEmpty;
  }

// 增加一条数据
  Future<void> insertDomain(String url) async {
    Database db = await database;
    await db.insert('Domain', {
      'url': url,
    });
  }

  // 更新一条数据
  Future<void> updateUrl(Map<String, dynamic> domain, String url) async {
    final db = await database;
    await db.update(
      'Domain',
      domain,
      where: 'url = ?',
      whereArgs: [url],
    );
  }
}

使用时

Dart 复制代码
  DatabaseHelper dbHelper = DatabaseHelper();

  Future<void> getDatabaseData() async {
    List<Map<String, dynamic>> data = await dbHelper.getItemsFromTable();
    for (var item in data) {
      print('Item: ${item.toString()}');
    }
  }
相关推荐
小雨下雨的雨10 分钟前
Flutter 框架跨平台鸿蒙开发 —— ListView 控件之高效列表渲染艺术
flutter·华为·harmonyos
行者9620 分钟前
Flutter在OpenHarmony平台的文件上传组件深度实践
flutter·harmonyos·鸿蒙
行者9623 分钟前
Flutter跨平台开发适配OpenHarmony:进度条组件的深度实践
开发语言·前端·flutter·harmonyos·鸿蒙
cn_mengbei25 分钟前
Flutter for OpenHarmony 实战:RangeSlider 范围滑块详解
flutter
奋斗的小青年!!26 分钟前
Flutter适配OpenHarmony:打造无缝国际化用户体验的实战指南
flutter·harmonyos·鸿蒙
奋斗的小青年!!27 分钟前
Flutter跨平台数据筛选器:深度适配OpenHarmony实战指南
flutter·harmonyos·鸿蒙
恋猫de小郭38 分钟前
Tailwind 因为 AI 的裁员“闹剧”结束,而 AI 对开源项目的影响才刚刚开始
前端·flutter·ai编程
奋斗的小青年!!2 小时前
Flutter与OpenHarmony深度协同:SnackBar组件的跨平台适配实战
flutter·harmonyos·鸿蒙
行者962 小时前
OpenHarmony Flutter跨平台开发:树形视图组件的实践与性能优化
flutter·性能优化·harmonyos·鸿蒙
LawrenceLan17 小时前
Flutter 零基础入门(九):构造函数、命名构造函数与 this 关键字
开发语言·flutter·dart