我正在为我的颤振应用程序使用Moor创建一个数据库。它有 5 个表和相应的 DAO(数据访问对象)。
@UseMoor(
tables: [Cart, CartTotal, Books, Subjects, Images],
daos: [CartDao, CartTotalDao, BooksDao, SubjectsDao, SearchDao, ImagesDao])
class AppDatabase extends _$AppDatabase {
AppDatabase()
: super(FlutterQueryExecutor.inDatabaseFolder(
path: 'db.sqlite', logStatements: true));
@override
int get schemaVersion => 1;
}
当我在模拟器上运行应用程序时,一切正常。所有表均已正确创建。当我在实际设备上运行应用程序时发生错误。3 个表创建良好,并按预期填充了来自云的数据。未创建购物车和总计的其他 2 个表,并且在访问购物车页面时会抛出no such table错误。
I/flutter ( 5321): Moor: Sent SELECT * FROM cart WHERE name != ? with args [Total]
E/SQLiteLog( 5321): (1) no such table: cart
也没有显示在应用程序启动时运行的我的数据库更新服务的日志记录。 从设备上的应用程序信息部分清除应用程序数据并再次启动应用程序后,一切正常。
I/flutter ( 5717): Moor: Sent CREATE TABLE IF NOT EXISTS books (amazon_link VARCHAR NULL, author VARCHAR NOT NULL, cost INTEGER NOT NULL, cover_url VARCHAR NULL, description VARCHAR NULL, discounted_cost INTEGER NULL, flipkart_link VARCHAR NULL, isbn INTEGER NOT NULL, language VARCHAR NULL, name VARCHAR NOT NULL, pages INTEGER NULL, publication_number INTEGER NOT NULL, publication_status VARCHAR NOT NULL, youtube_link VARCHAR NULL, PRIMARY KEY (publication_number)); with args []
I/flutter ( 5717): Moor: Sent CREATE TABLE IF NOT EXISTS subjects (publication_number INTEGER NOT NULL, sub_name VARCHAR NOT NULL, PRIMARY KEY (publication_number, sub_name)); with args []
I/flutter ( 5717): Moor: Sent CREATE TABLE IF NOT EXISTS images (url VARCHAR NOT NULL, publication_number INTEGER NOT NULL); with args []
I/flutter ( 5717): Moor: Sent CREATE TABLE IF NOT EXISTS cart (name VARCHAR NOT NULL, quantity INTEGER NOT NULL, cost INTEGER NOT NULL, discounted_cost INTEGER NOT NULL, PRIMARY KEY (name)); with args []
I/flutter ( 5717): Moor: Sent CREATE TABLE IF NOT EXISTS cart_total (name VARCHAR NOT NULL, quantity INTEGER NOT NULL, cost INTEGER NOT NULL, discounted_cost INTEGER NOT NULL, PRIMARY KEY (name)); with args []
打开购物车页面按预期工作。
I/flutter ( 5717): Moor: Sent SELECT * FROM cart WHERE name != ? with args [Total]
I/flutter ( 5717): Moor: Sent SELECT * FROM cart_total WHERE name = ?; with args [Total]
我在这里错过了什么吗?我还搜索了创建表是否有任何限制,但找不到任何限制。由于 moor 通过使用 build_runner 生成代码来工作,我还尝试清除旧版本并再次重建。
由于应用程序在清除数据后在模拟器和设备上运行良好,因此我假设我的代码是正确的。可能是什么问题呢?