2

我正在为我的颤振应用程序使用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 生成代码来工作,我还尝试清除旧版本并再次重建。

由于应用程序在清除数据后在模拟器和设备上运行良好,因此我假设我的代码是正确的。可能是什么问题呢?

4

1 回答 1

1

所以问题不在于 moor 或我的代码。由于该应用程序尚未发布并且我仍在对数据库进行更改,因此我不想更改架构版本并提供迁移策略。

我的理解是,数据库将在应用程序卸载时被删除,并且对数据库所做的任何更改都将成为我下次安装应用程序时的新架构。事实并非如此。至少并非总是如此。

事实证明,Google Drive 会在某些设备上备份您的应用程序的数据库文件,并在重新安装应用程序时将其恢复。这就是导致我的应用程序出现奇怪行为的原因。

这是github问题的链接以获取详细说明。

于 2019-10-25T06:19:11.287 回答