4

我断断续续地SQLiteException声称“没有这样的表:HomepageSection”。它始终是同一张表,但停止应用程序并重新启动它,问题就消失了。如果数据库丢失,有时会发生这种情况,有时会在数据库存在时发生。

这些表是在打开数据库文件时使用sqlite-netSQLiteAsyncConnection.CreateTableAsync方法创建的(是的,在此异常发生之前它们会被等待)。

我正在连接到正确的数据库文件,我已经检查了多次。我直接在 SQLite 浏览器中打开从连接对象获得的路径,但HomepageSection表不存在。

引发以下SQLiteException查询:insert OR REPLACE into "HomepageSection"("Title","Version","Id","Updated") values (?,?,?,?)(SQLite.cs,Prepare2(),第 2951 行)

据称创建表的行没有抛出异常:

await _connection.CreateTableAsync<HomepageSection>();

解决这个问题的想法?

4

2 回答 2

1

我遇到了同样类型的间歇性错误。我进行了以下更改,到目前为止,还没有客户报告新的错误。

我在连接字符串中关闭了 sqlite 自动创建数据库。

connectionString="Data Source=default.db3; Foreign Keys=true; FailIfMissing=True;"

打开 FailIfMissing 后,我收到了无法打开数据库而不是没有这样的表的报告。似乎 sqlite 无法打开我的 db3 文件,因此它创建了一个没有表的新数据库。它必须在内存中创建它,因为我在驱动器上找不到任何新的 db 文件。

为了纠正这个问题,我使用单例模式只建立一个连接并在应用程序的整个生命周期中保持打开状态。还有其他方法可以做到这一点,但我对单例有更多的经验。这不是完整的课程代码,只是让您入门的几个部分。

public static SQLite Instance
{
  get
  {
    if (instance == null) 
      {
        instance = new SQLite();
        mySQLiteConn = new SQLiteConnection(ConnectionString);
        mySQLiteConn.Open();
      }
      return instance;
  }
}

public void Execute(string SQL)
{
  using (SQLiteCommand myCommand = new SQLiteCommand(SQL, mySQLiteConn))
  {
    myCommand.ExecuteNonQuery().ToString();
  }
}

所以要执行插入,你会这样做:

SQLite.Instance.Execute("Insert .....;");
于 2013-08-23T18:36:54.573 回答
0

我有一个类似的问题。我所做的只是创建表(没有查询,没有别的),并通过直接查看数据库来查看表是否真的被创建。在这里,您可以了解您的数据结构是否存在问题。您已经完成了大多数事情,但如果未创建表,您应该调查原因。

在我的情况下,我在intstring(id 字段和主键)之间有些混淆,而且我也忘记为一对一连接创建一个 id 属性。大多数情况下,异常并不能提供信息,但您应该始终捕获异常并找到内部异常。有时他们可以给你一个提示。

于 2017-07-14T12:33:51.610 回答