none
vs输出窗口显示异常,但是程序没有报错,找不到报错的位置 RRS feed

答案

  • 你的错误信息是:Database is locked。

    既然你用SQLite,SQLite只支持库级锁,库级锁意味着什么?——意味着同时只能允许一个写操作,也就是说,即事务T1在A表插入一条数据,事务T2在B表中插入一条数据,这两个操作不能同时进行,即使你的机器有100个CPU,也无法同时进行,而只能顺序进行。表级都不能并行,更别说元组级了——这就是库级锁。但是,SQLite尽量延迟申请X锁,直到数据块真正写盘时才申请X锁,这是非常巧妙而有效的。

    解决方案:每次保证同一时刻是最多只允许一个update语句进行更新(建议用lock进行操作)。


    ASP.NET Forum
    StackOverFlow
    FreeRice Donate
    Issues to report



    2017年8月4日 14:13