加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

SQLite.NET PCL忙碌异常

发布时间:2020-12-12 18:57:58 所属栏目:百科 来源:网络整理
导读:我们在Xamarin应用程序中使用SQLite.NET PCL. 通过插入多个表将数据库置于压力之下,我们看到抛出BUSY异常. 任何人都可以解释BUSY和LOCKED之间的区别吗?是什么导致数据库忙? 我们的代码使用与使用以下代码创建的数据库的单个连接: var connectionString =
我们在Xamarin应用程序中使用SQLite.NET PCL.

通过插入多个表将数据库置于压力之下,我们看到抛出BUSY异常.

任何人都可以解释BUSY和LOCKED之间的区别吗?是什么导致数据库忙?

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

var connectionString = new SQLiteConnectionString(GetDefaultConnectionString(),_databaseConfiguration.StoreTimeAsTicks);
var connectionWithLock = new SQLiteConnectionWithLock(new SQLitePlatformAndroid(),connectionString);

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

解决方法

所以我们的问题结果是,虽然我们已经确保在类中我们写了它只创建了一个到数据库的单一连接,我们还没有确保这个类是一个单例,因此我们仍然创建了多个连接到数据库.一旦我们确定它是单身,那么繁忙的错误就会停止

我从中得到的是:

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读