注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

信息 灵感 创新

III = Information,Inspiration,Innovation

 
 
 

日志

 
 
关于我

we are 5. Mathematics, Computation, Programming, Engineering, and Making fun of life.

网易考拉推荐

SQLite数据库文件大小不变的问题  

2017-02-08 16:17:43|  分类: C# & .NET |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
这个问题在网上都有描述,估计很多人也有碰到过,就是在SQLite中删除了大量的数据记录之后,数据库文件的大小没有变,而且,在Update了之后,居然还把体积翻倍了。
出现这个问题的原因是,SQLite文件在创建的时候,一般也就1k左右(与创建的设置有关),在向SQLite数据库文件中写入数据的时候,SQLite会根据数据的大小自动扩容,但是,再删除的时候,SQLite并不会自动地减少储存空间,而是把多出来的空间,添加到一个内在的”空闲列表”中,用于存储下次插入的数据,磁盘空间并没有出现丢失,也不向操作系统返回多出来的磁盘空间。
如何解决这个问题呢?
两种方案:
一种方案是,在创建数据库的时候,设置Auto Vacuum选项:
SQLite数据库文件大小不变的问题 - Lemniscate - 信息 灵感 创新
 
另外一种方案是,在操作完成之后,执行 VACUUM 命令,C#中可以这么写:
                string sql = "VACUUM table_name;
                SQLiteCommand cmd = new SQLiteCommand(sql, conn);
                cmd.ExecuteNonQuery();
不过据说执行该命令效率较低。
  评论这张
 
阅读(102)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017