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垃圾回收之后才能真正释放连接。

  • 相关阅读:
    C# 观察者模式(Observer)
    CXGRID设置Selstart和SelLength
    Delphi 中相对路径与绝对路径、系统环境变量等相关函数说明
    用Delphi创建一个空的Access数据库
    非COM环境下的接口编程
    VCLZIP样例
    delphi 文件CRC32校验
    delphi中无类型文件读写
    Delphi调用MSSQL存储过程返回的多个数据集
    CXGRID,定位并高亮
  • 原文地址:https://www.cnblogs.com/kangxia/p/7458961.html
Copyright © 2011-2022 走看看