首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLite.NET PCL忙异常

SQLite.NET PCL忙异常
EN

Stack Overflow用户
提问于 2016-09-19 15:40:40
回答 3查看 4.3K关注 0票数 5

我们在Xamarin应用程序中使用SQLite.NET PCL。

当通过在多个表中插入使数据库处于压力下时,我们看到会抛出繁忙的异常。

有人能解释一下忙和锁之间的区别吗?是什么使数据库忙碌呢?

我们的代码使用一个连接到使用以下代码创建的数据库:

代码语言:javascript
复制
var connectionString = new SQLiteConnectionString(GetDefaultConnectionString(), 
                                                      _databaseConfiguration.StoreTimeAsTicks);
var connectionWithLock = new SQLiteConnectionWithLock(new SQLitePlatformAndroid(), connectionString);

return new SQLiteAsyncConnection (() => { return connectionWithLock; });
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2016-09-21 07:28:26

因此,我们的问题是,尽管我们在类中确保了我们只创建了一个到数据库的连接,但是我们没有确保这个类是一个单例,因此我们仍然在创建到数据库的多个连接。一旦我们确定它是单例,那么繁忙的错误就停止了。

我从这里学到的是:

锁定意味着您有多个线程试图访问数据库,代码本身并不是线程安全的。

繁忙意味着有一个线程在等待另一个线程完成,您的代码是线程安全的,但是在使用数据库时会看到争用。

票数 8
EN

Stack Overflow用户

发布于 2016-09-19 15:54:50

...current操作无法继续,因为所需资源是锁定的.

我假设您使用的是异步-style插入,并且位于不同的线程上,因此插入正在超时,等待不同插入的锁完成。您可以使用同步插入来避免这种情况。在需要时,我会通过创建FIFO队列并在专用线程上同步使用该队列来避免这种情况。您还可以通过重新尝试您的事务X次数来处理该条件,然后再让Exception触发。

SQLiteBusyException是一个特殊的异常,每当SQLite返回SQLITE_BUSY或SQLITE_IOERR_BLOCKED错误代码时都会抛出该异常。这些代码意味着由于所需资源被锁定,当前操作无法进行。 当通过SQLiteConnection.setBusyTimeout(long)设置超时时,SQLite将在返回此错误之前尝试在指定的超时期间获取锁。

参考文献:http://www.sqlite.org/lockingv3.html

参考文献:timeout

票数 7
EN

Stack Overflow用户

发布于 2022-06-08 05:06:53

我已经应用了下面的解决方案,在我的情况下(移动应用程序)。

  1. 使用sqlitepclraw.bundle_green金块包和SqlitePCL。
  2. 试着在整个应用程序中使用单一连接。
  3. 在创建SQLiteConnection之后。

使用下面的调用应用繁忙时间。

代码语言:javascript
复制
var connection = new SQLiteConnection(databasePath: path);
SQLite3.BusyTimeout(connection.Handle, 5000); // 5000 millisecond.
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39577042

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档