flutter sqflite : Database unstable after hot reload

标签 flutter dart sqflite

我有以下代码

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

其中函数 open 如下
  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 <db_name>.db true )
在执行查询之前的行(await _db.query(...);)

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

最佳答案

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

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

如果您在这种情况下,可以确保永远不会调用 close() 吗? (并尝试评论此代码)

关于 flutter sqflite : Database unstable after hot reload,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61599995/

相关文章:

dart - Flutter Overlapped InkWells 手势检测

sql - 我该如何解决?Flutter sqflite删除不起作用

flutter - Statefulwidget不刷新ListView

javascript - Laravel和Flutter通知系统

dart - Flutter:如何在没有 android 底部导航栏的情况下显示屏幕键盘以聚焦文本字段?

dart - dart和flutter构建的内核文件有什么区别?

firebase - 实现Firebase登录时AngularDart引发错误

dart - 如何打开弹出菜单按钮?

flutter - 如何获得抖动中的平均颜色?

database - Flutter中的Sqlite,数据库 Assets 如何工作