VACUUM命令是SQLite的一个扩展功能,模仿PostgreSQL中的相同命令而来。若调用VACUUM带一个表名或索引名, 则将整理该表或索引。在SQLite 1.0中,VACUUM命令调用 gdbm_reorganize()整理后端数据库文件。

SQLITE 2.0.0中去掉了GDBM后端,VACUUM无效。在2.8.1版中,VACUUM被重新实现。现在索引名或表名被忽略。

当数据库中的一个对象(表,索引或触发器)被撤销,会留下空白的空间。它使数据库比需要的大小更大,但能加快插入速度。实时的插入和删除会使得数据库文件结构混乱,减慢对数据库内容访问的速度。 VACUUM命令复制主数据库文件到临时数据库并从临时数据库重新载入主数据库,以整理数据库文件。这将除去空白页,使表数据彼此相邻排列,并整理数据库文件结构。不能对附加数据库文件进行以上操作。

若当前有活动事务,该命令无法起作用。对于in-memory数据库,该命令无效。

SQLite3.1中,可以通过使用auto-vacuum模式取代VACUUM命令,使用 auto_vacuum pragma开启该模式。

VACUUM的使用:VACUUM main
当对3.4节中讨论的数据进行VACUUM操作后,页面只剩第一个页面。

VACUUM实现:


代码实现(vcuum.c):

  1.  
  2. int sqlite3RunVacuum(char **pzErrMsg, sqlite3 *db){
  3. ///////////////////////////////////第1步////////////////////////////////////////////////
  4. zSql = sqlite3MPrintf("ATTACH '%q' AS vacuum_db;", zTemp);
  5.   //创建临时数据库vacuum_db
  6.   rc = execSql(db, zSql);
  7. ///////////////////////////////////第2步////////////////////////////////////////////////
  8. //开始一个事务
  9.   rc = execSql(db, "BEGIN EXCLUSIVE;");
  10. ///////////////////////////////////第3步////////////////////////////////////////////////
  11. //在vacuum_db中建立main数据库的所有表,索引和视图,并将main中的所有表,索引和视图的数据插入
  12.   //到vacuum_db。即在vacuum_db建立main的镜象。
  13.   rc = execExecSql(db, 
  14.       "SELECT 'CREATE TABLE vacuum_db.' || substr(sql,14,100000000) "
  15.       "  FROM sqlite_master WHERE type='table' AND name!='sqlite_sequence'");
  16.   if( rc!=SQLITE_OK ) goto end_of_vacuum;
  17.   rc = execExecSql(db, 
  18.       "SELECT 'CREATE INDEX vacuum_db.' || substr(sql,14,100000000)"
  19.       "  FROM sqlite_master WHERE sql LIKE 'CREATE INDEX %' ");
  20.   if( rc!=SQLITE_OK ) goto end_of_vacuum;
  21.   rc = execExecSql(db, 
  22.       "SELECT 'CREATE UNIQUE INDEX vacuum_db.' || substr(sql,21,100000000) "
  23.       "  FROM sqlite_master WHERE sql LIKE 'CREATE UNIQUE INDEX %'");
  24.   if( rc!=SQLITE_OK ) goto end_of_vacuum;
  25.   rc = execExecSql(db, 
  26.       "SELECT 'CREATE VIEW vacuum_db.' || substr(sql,13,100000000) "
  27.       "  FROM sqlite_master WHERE type='view'"
  28.   );
  29. rc = execExecSql(db, 
  30.       "SELECT 'INSERT INTO vacuum_db.' || quote(name) "
  31.       "|| ' SELECT * FROM ' || quote(name) || ';'"
  32.       "FROM sqlite_master "
  33.       "WHERE type = 'table' AND name!='sqlite_sequence';"
  34.   );
  35. ///////////////////////////////////第4步////////////////////////////////////////////////
  36.     //将vacumm_db数据库对应的数据文件的数据拷贝到main数据库对应的数据文件,一个页面一个页面的拷贝
  37. rc = sqlite3BtreeCopyFile(pMain, pTemp);
  38. ///////////////////////////////////第5步////////////////////////////////////////////////
  39.     //提交事务
  40.     rc = sqlite3BtreeCommit(pTemp);
  41.     if( rc!=SQLITE_OK ) goto end_of_vacuum;
  42.     rc = sqlite3BtreeCommit(pMain);
  43. }

SQLite入门与分析(九)---VACUUM命令分析的更多相关文章

  1. SQLite 入门教程 (终端)命令

    一.基本简介 SQLite 是一个自持的(self-contained).无服务器的.零配置的.事务型的关系型数据库引擎.因为他很小,所以也可以作为嵌入式数据库内建在你的应用程序中.SQLite 被应 ...

  2. SQLite入门与分析(三)---内核概述(2)

    写在前面:本节是前一节内容的后续部分,这两节都是从全局的角度SQLite内核各个模块的设计和功能.只有从全局上把握SQLite,才会更容易的理解SQLite的实现.SQLite采用了层次化,模块化的设 ...

  3. SQLite入门与分析(二)---设计与概念(续)

    SQLite入门与分析(二)---设计与概念(续)   写在前面:本节讨论事务,事务是DBMS最核心的技术之一.在计算机科学史上,有三位科学家因在数据库领域的成就而获ACM图灵奖,而其中之一Jim G ...

  4. SQLite入门与分析(八)---存储模型(1)

    写在前面:SQLite作为嵌入式数据库,通常针对的应用的数据量相对于通常DBMS的数据量是较小的.所以它的存储模型设计得非常简单,总的来说,SQLite把一个数据文件分成若干大小相等的页面,然后以B树 ...

  5. 【军哥谈CI框架】之入门教程之第二讲:分析CI结构和CI是怎么工作的

    [军哥谈CI框架]之入门教程之第二讲:分析CI结构和CI是怎么工作的   之入门教程之第二讲:分析CI结构和CI是如何工作的大家好!上一节,我们共同部署了一个CI网站,做到这一点非常简单,但是,亲们, ...

  6. SQLite 入门教程(一)基本控制台(终端)命令 (转)

    转于: SQLite 入门教程(一)基本控制台(终端)命令 一.基本简介   SQLite 是一个自持的(self-contained).无服务器的.零配置的.事务型的关系型数据库引擎.因为他很小,所 ...

  7. 手机自动化测试:Appium源码分析之跟踪代码分析九

    手机自动化测试:Appium源码分析之跟踪代码分析九   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家 ...

  8. (数字IC)低功耗设计入门(二)——功耗的分析

    前面学习了进行低功耗的目的个功耗的构成,今天就来分享一下功耗的分析.由于是面向数字IC前端设计的学习,所以这里的功耗分析是基于DC中的power compiler工具:更精确的功耗分析可以采用PT,关 ...

  9. 第1阶段——uboot分析之查找命令run_command函数和命令定义过程(6)

    本节主要学习,run_command函数命令查找过程,命令生成过程 1.run_command函数命令查找过程分析:在u-boot界面中(main_loop();位于u-boot-1.1.6/comm ...

随机推荐

  1. beanfactory与applicationcontext的区别

    ApplicationContext能够自动辨认和应用在其上部署的实现了BeanFactoryPostProcessor的bean 特性                            Bean ...

  2. OPENSSL中RSA私钥文件(PEM格式)解析【一】

    http://blog.sina.com.cn/s/blog_4fcd1ea30100yh4s.html 在PKCS#1 RSA算法标准中定义RSA私钥语法为: RSAPrivateKey ::= S ...

  3. python备份脚本

    备份制定文件到指定目录下,文件名以当前时间 思路: 1.指定备份的文件或目录 2.指定备份的目标路径 3.压缩备份名是当前日期和时间 4.使用标准的压缩命令 1.最简单的以日期时间为文件名 2.以日期 ...

  4. spring中加入log4j

    spring中加入log4j <context-param> <param-name>log4jConfigLocation</param-name> <pa ...

  5. 学习之spring注解DI疑惑

    接口定义 package com; public interface IPaly { void say(); } 接口实现类 package com; import org.springframewo ...

  6. [.Net MVC] 用户角色权限管理_使用CLK.AspNet.Identity

    项目:后台管理平台 意义:一个完整的管理平台需要提供用户注册.登录等功能,以及认证和授权功能. 一.为何使用CLK.AspNet.Identity 首先简要说明所采取的权限控制方式.这里采用了基于角色 ...

  7. Vue.js中Directive知识

    近期所学的Vue.js这个MVVM前端技术缓解了我一直愁于前后端开发杂糅所带来的痛苦.今天就来说说关于Vue.js里面的Directive知识. Directive Directive看上去虽然和An ...

  8. 【Java咬文嚼字】关键字(一):super和this

    这段时间一直在学Java,看了辣么多书以及博客,心痒也是着写写自己的学习心得. 这也算是新手篇:咬文嚼字Java中的关键字. 以关键字为第一篇博文也是考虑再三:1.本人基础也是薄弱 2.集跬步至千里 ...

  9. Unable to make the session state request to the session state server处理方法

    Server Error in '/' Application. Unable to make the session state request to the session state serve ...

  10. 数据库之mysql 视图

    视图,把基本表的某些数据组合起来构成一个虚拟表的一种形式,之所以叫虚拟,是因为只有当视图用于一条语句中的时候,它才能存在.同时如果对视图中的数据进行修改,会同时修改到基本表中的数据. 创建视图: cr ...