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()}');
    }
  }
相关推荐
只可远观12 小时前
Flutter目录结构介绍、入口、Widget、Center组件、Text组件、MaterialApp组件、Scaffold组件
前端·flutter
周胡杰12 小时前
组件导航 (HMRouter)+flutter项目搭建-混合开发+分栏效果
前端·flutter·华为·harmonyos·鸿蒙·鸿蒙系统
肥肥呀呀呀12 小时前
flutter Stream 有哪两种订阅模式。
flutter
WDeLiang20 小时前
Flutter - 集成三方库:日志(logger)
flutter·dart
hudawei99621 小时前
flutter缓存网络视频到本地,可离线观看
flutter·缓存·音视频
0wioiw02 天前
Flutter基础()
flutter
肥肥呀呀呀2 天前
flutter 视频通话flutter_webrtc
flutter
明似水2 天前
2025年Flutter项目管理技能要求
flutter
肥肥呀呀呀2 天前
flutter使用命令生成BinarySize分析图
flutter
程序猿阿伟2 天前
《数字分身进化论:React Native与Flutter如何打造沉浸式虚拟形象编辑》
flutter·react native·react.js