Flutter sqflite:热重载后数据库不稳定
Flutter sqflite: Database unstable after hot reload
我有以下代码
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 正在做什么以了解错误的上下文,
您可以查看
sqflite 通过查找打开的数据库(如果有)支持热重启(即 dart 端重启但本机数据库仍然打开)。热重载应该不会造成任何问题。
我唯一能想到的是,如果您在某处接到 _db.close()
电话。在典型的单一数据库场景中,您应该在启动时简单地打开数据库,永远不要关闭它。
如果您遇到这种情况,能否确保永远不会调用 close()? (并尝试评论这段代码)
我有以下代码
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 正在做什么以了解错误的上下文,
您可以查看
sqflite 通过查找打开的数据库(如果有)支持热重启(即 dart 端重启但本机数据库仍然打开)。热重载应该不会造成任何问题。
我唯一能想到的是,如果您在某处接到 _db.close()
电话。在典型的单一数据库场景中,您应该在启动时简单地打开数据库,永远不要关闭它。
如果您遇到这种情况,能否确保永远不会调用 close()? (并尝试评论这段代码)