【问题标题】:Flutter sqflite: Database unstable after hot reloadFlutter sqflite:热重载后数据库不稳定
【发布时间】:2020-08-19 08:06:22
【问题描述】:

我有以下代码

  Future<InitData> getInitialData() async {
    print('OPENING');
    await open();
    print('DB = $_db ${_db.isOpen}');
    final rawDayActionTypes = await _db.query(...);

函数打开的地方如下

  Future<Database> open() async {
    if (_db != null && _db.isOpen) {
      return _db;
    }

    final dbPath = await sql.getDatabasesPath();
    final myDBPath = path.join(dbPath, db_name);
    _db = await sql.openDatabase(myDBPath, onCreate: _onCreateDB, version: 1);
    return _db;
  }

但是在热重载后,我经常收到以下错误:

I/flutter (10806): DB = 1161 <db_name>.db true
E/flutter (10806): [ERROR:flutter/lib/ui/ui_dart_state.cc(157)] Unhandled Exception: DatabaseException(error database_closed)
E/flutter (10806): #0      SqfliteDatabaseMixin.checkNotClosed 
package:sqflite_common/src/database_mixin.dart:282
E/flutter (10806): #1      SqfliteDatabaseExecutorMixin._rawQuery 
package:sqflite_common/src/database_mixin.dart:125
E/flutter (10806): #2      SqfliteDatabaseExecutorMixin.query 
package:sqflite_common/src/database_mixin.dart:110
E/flutter (10806): #3      DBService.getInitialData 
package:productive_diary/db/db_service.dart:56
E/flutter (10806): <asynchronous suspension>
E/flutter (10806): #4      _InitDBDataState._fetchData 
package:productive_diary/initScreen.dart:53
E/flutter (10806): #5      _InitDBDataState.didChangeDependencies 

如您所见,数据库已打开 (DB = 1161 &lt;db_name&gt;.db true)
执行查询前上线(await _db.query(...);)

如果您需要知道 _InitDBDataState 正在做什么以了解错误的上下文,
您可以查看this related question

【问题讨论】:

    标签: flutter dart sqflite


    【解决方案1】:

    sqflite 通过查找打开的数据库(即 dart 端重新启动但本机数据库仍处于打开状态)来支持热重启。热重载不会导致任何问题。

    我唯一能想到的就是如果你在某个地方有一个_db.close() 电话。在典型的单一数据库场景中,您应该在启动时简单地打开数据库,而永远不要关闭它。

    如果你在这种情况下,可以确保 close() 永远不会被调用? (并尝试注释此代码)

    【讨论】:

    • 是的,你是对的,它解决了我的问题。但我很困惑。不应该像读写文件时那样为每组操作打开和关闭数据库吗?至少当我的应用程序被分离并再次恢复时,不应该关闭并打开数据库吗?
    • 打开数据库是一项昂贵的操作,除非您包装所有调用以确保数据库已打开,否则您可能会处理 database_close 问题。如果您像大多数人在 Android 和 iOS 上那样经常访问数据库,我个人会保持打开状态。我不知道要保持打开状态需要多少 RAM。
    • 那么什么时候应该有人调用 db.close()?
    • 一种情况:您有一个数据库来为当前用户缓存一些 Web 服务数据。您可以决定每个登录用户拥有一个数据库,当用户更改时,您可以关闭当前数据库以打开一个新数据库。
    猜你喜欢
    • 1970-01-01
    • 2021-07-09
    • 1970-01-01
    • 1970-01-01
    • 2019-04-07
    • 2021-08-21
    • 2021-09-14
    • 2021-10-12
    • 1970-01-01
    相关资源
    最近更新 更多