Sqlite3数据库教程.docVIP

  1. 1、本文档共15页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Sqlite3数据库教程

?数据库--sqlite的操作 一、数据库基本概念 A.数据(Data) 能够输入计算机并能被计算机程序识别和处理的信息集合。 B.数据库(Database) 数据库是在数据库管理系统管理和控制之下,存放在存储介质上的数据集合。 注意:数据库管理系统(DataBase Mangement System) --DBMMS C.数据库管理系统(DBMS) DBMS是数据库系统中对数据进行统一管理和控制的软件系统 (1)数据库定义功能 ?(Data Definition) (2)数据库操纵功能 ?(Data Manpulation) (3)数据库运行控制功能 ?(Data Control) (4)数据通信功能(Data ?Communication) 即 为应用程序提供的访问接口 (5)支持存取海量数据(Mass Data) 二、文件管理和数据库管理 A.文件管理阶段 优点 : (i)数据可长期保存 ? ? ? ? ? (ii)能存储大量数据 缺点: (i)数据冗余度(redundancy)、数据一致性(consistency)、完整性(integrity)难以维持 ? ? ? ? ?(ii)数据与程序缺乏高度独立性 B.数据库系统阶段 (i)数据组织结构化 (ii)数据冗余度比较小,易扩充 (iii)具有较高的数据与程序之间的独立性 (iv)统一的数据控制 三、常用的数据库介绍 A.大型数据库 Oracle公司是最早开发关系数据库的厂商之一,其产品支持最广泛的操作系统平台。目前Oracle关系数据库产品的市场占有率名列前茅。 IBM的DB2是第一个具备网上功能的多媒体关系数据库管理系统,支持包括Linux在内的一系列平台。 B.中型数据库 SQLServer是微软开发的数据库产品,主要支持windows平台。 C.小型数据库 mysql是一个小型关系型数据管理系统,开发者为瑞典mysql AB公司,2005年被sun公司收购。开放 源码。 D.基于嵌入式Linux的数据库 1.基于嵌入式linux的数据库主要有SQLite,Firbird,Berkeley DB,extremeDB 2.Firebird是关系型数据库,功能强大,支持存储过程、SQL兼容等 3.SQLite关系型数据库,体积小,支持 ACID(原子性、一致性、独立性及持久性 Atomicity、Consistency、Isolation、Durability)事物。 4.Berkeley DB中并米有数据库服务器的概念,它的程序库直接连接到应用程序中 5.extremeDB是内存数据库,运行效率高 ?? 四、sqlite的介绍 A.sqlite的源代码是C,其源代码完全开放。sqlite第一个Alpha版本诞生于2000年5月。他是一个轻量级的嵌入式数据库。 B.sqlite有一下特性 1零配置,无需安装和配置 2储存在单一磁盘文件中的一个完整的数据库 3数据库文件可以在不同字节顺序的机器间自由共享 4支持数据库大小之2TB 5足够小,全部源代码大致3万行C代码,250KB 6比目前流行的大多数数据库对数据的操作要快 C.sqlite数据库工作原理 sqlite数据库采用模块化设计,由8个独立的模块构成,这些独立模块又构成了三个主要的子系统,模块将复杂的查询过程分解为细小的工作进行处理。? sqlite主要由7个构件子系统(也就是模块)组成,这些模块被分割为两个部分: 前端解析系统和后端引擎。 前端: 前端预处理应用程序传递过来的SQL语句和SQLite命令。对获取的编码分析,优化,并转换 为后端能够执行的SQLite内部字节编码。前端可分为三个模块: 1标示分析(Tokenizer) 将输入的SQL语句分成标识符; 2语法分析(Parser) 解析器分析通过标识器产生的标识分析语句的结构,并且得到一颗语法树。解析器同时也包含了重构语法树的优化器,因此能够找到一颗产生一个高效的字节编码程序的语法树。 3代码生成器(Code Generator) 代码生成器遍历语法树,并且生成一个等价的字节编码程序 前端实现了sqlite3_prepare API函数 后端: 后端是用来解释字节编码程序的引擎。该引擎做的才是真正的数据库处理工作。后端部分由四个模块组成: 1虚拟机(VM) ? ?? VM模块是一个内部字节编码语言的解释器。它通过执行字节编码语句来实现SQL语句的工作。它是数据库中数据的最终的操作者。它把数据库看成表和索引的集合,而表和索引则是一系列的元组或者记录。 2B/B+树 B/B+树模块把每一个元组集组织进一个一次排好序的树状数据结构中,表和索引被分别置于单独的B+和B树中。该模块帮助VM进行搜索,插入和删除树中的元组。它也帮助VM创建新的树和删除旧的树

文档评论(0)

dajuhyy + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档