zoukankan      html  css  js  c++  java
  • 如何删除当前正在使用的SQLLite文件?

    从网上搜索一大堆,套路几乎相同,但自己就是不行,怎么也不行,为什么不行呢?不行的话别人肯定不来坑博友了呀。然后放了一会,去拿下午茶回来,再次来看,恍然大悟,What?这么简单。

    一开始代码如下:

    helper.GetConnectionString(schoolStr);//获取当前连接字符串    
    using (ConnectionBase conn = ConnectionManager.Instance.Pop())
    {
    if (conn.State != ConnectionState.Open)
    conn.Open();
    try
    {
    helper.GetConnectionString(schoolStr);//获取当前连接字符串  
    var curSchoolInfo = schoolDAL.SelectDetail(schoolStr);
    if (curSchoolInfo != null)
    schoolInfoList.Add(curSchoolInfo);
    }
    finally
    {
    conn.Close();
    conn.Dispose();
    GC.Collect();
    GC.WaitForPendingFinalizers();
    }
    }

    修改后代码如下:

    只要把红色字体部分去掉,放到粉色字体部分就好了。

    就是这么简单的问题,花了2个多小时折腾。

    注意蓝色字体部分代码:

    如果不加蓝色字体部分代码,表面看着已经释放了,实则不然,为什么close()和Dispose()之后任然不能释放与db文件的连接呢?问度娘,好几个答案是:Close() ,Dispose() ,但还是不可以,再次问度娘,给出了如下答案:

    原因是sqllite在执行 SQLiteConnectionHandle.Dispose()操作的时候,其实并没有真正的释放连接,只有显示调用CLR垃圾回收之后才能真正释放连接。

  • 相关阅读:
    link和@import的区别
    行内元素、块状元素和行内块元素
    content-box与border-box区别
    实现浏览器内多个标签页之间的通信
    cookie、 sessionStorage 、localStorage之间的区别和使用
    让浏览器识别HTML5规范中的新标签
    HTML5新增及移除的元素
    摇一摇
    WebViewJavascriptBridge
    使用TFHpple解析html
  • 原文地址:https://www.cnblogs.com/kangxia/p/7458961.html
Copyright © 2011-2022 走看看