如何删除当前正在使用的SQLLite文件?_.NET_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > .NET > 如何删除当前正在使用的SQLLite文件?

如何删除当前正在使用的SQLLite文件?

 2017/8/31 18:08:48  番茄酱子  程序员俱乐部  我要评论(0)
  • 摘要:从网上搜索一大堆,套路几乎相同,但自己就是不行,怎么也不行,为什么不行呢?不行的话别人肯定不来坑博友了呀。然后放了一会,去拿下午茶回来,再次来看,恍然大悟,What?这么简单。一开始代码如下:helper.GetConnectionString(schoolStr);//获取当前连接字符串using(ConnectionBaseconn=ConnectionManager.Instance.Pop()){if(conn.State!=ConnectionState.Open)conn.Open
  • 标签:使用 文件 SQL

从网上搜索一大堆,套路几乎相同,但自己就是不行,怎么也不行,为什么不行呢?不行的话别人肯定不来坑博友了呀。然后放了一会,去拿下午茶回来,再次来看,恍然大悟,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垃圾回收之后才能真正释放连接。

发表评论
用户名: 匿名