我在sqflite数据库中添加了新列。之后,更新应用程序时无法使用我的应用程序。我应该卸载并重新安装。如何处理这种情况?
class HelperDatabase1 {
static final HelperDatabase1 _instance = HelperDatabase1.internal();
factory HelperDatabase1() => _instance;
static Database _db;
Future<Database> get db1 async {
if (_db != null) return _db;
_db = await initDb();
return _db;
}
HelperDatabase1.internal();
initDb() async {
io.Directory documentsDirectory = await getApplicationDocumentsDirectory();
String path = join(documentsDirectory.path, "HelperDatabase.db");
var theDb = await openDatabase(path, version: 2, onCreate: _onCreate);
return theDb;
}
void _onCreate(Database db, int version) async {
await db.execute("CREATE TABLE GetUserPreferenceTable(id INTEGER PRIMARY KEY AUTOINCREMENT, data INTEGER)");
}
在我的main.dart中
var helper;
void main() async {
// debugPaintSizeEnabled=false;
helper =
await HelperDatabase1();
答案 0 :(得分:0)
没有看到您的特定错误,很可能需要在openDatabase()方法中增加数据库的版本号以通知架构更改。
例如,如果您使用类似于以下代码的代码来创建数据库,则可以将版本从1增加到2:
createDatabase() async {
String databasesPath = await getDatabasesPath();
String dbPath = join(databasesPath, 'my.db');
var database = await openDatabase(dbPath, version: 2, onCreate: populateDb);
return database;
}