您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 项目/工程管理 > Sqlite3数据库
数据库--sqlite的操作2012-06-1120:54:55分类:SQLite/嵌入式数据库一、数据库基本概念A.数据(Data)能够输入计算机并能被计算机程序识别和处理的信息集合。B.数据库(Database)数据库是在数据库管理系统管理和控制之下,存放在存储介质上的数据集合。注意:数据库管理系统(DataBaseMangementSystem)--DBMMSC.数据库管理系统(DBMS)DBMS是数据库系统中对数据进行统一管理和控制的软件系统(1)数据库定义功能(DataDefinition)(2)数据库操纵功能(DataManpulation)(3)数据库运行控制功能(DataControl)(4)数据通信功能(DataCommunication)即为应用程序提供的访问接口(5)支持存取海量数据(MassData)二、文件管理和数据库管理A.文件管理阶段优点:(i)数据可长期保存(ii)能存储大量数据缺点:(i)数据冗余度(redundancy)、数据一致性(consistency)、完整性(integrity)难以维持(ii)数据与程序缺乏高度独立性B.数据库系统阶段(i)数据组织结构化(ii)数据冗余度比较小,易扩充(iii)具有较高的数据与程序之间的独立性(iv)统一的数据控制三、常用的数据库介绍A.大型数据库Oracle公司是最早开发关系数据库的厂商之一,其产品支持最广泛的操作系统平台。目前Oracle关系数据库产品的市场占有率名列前茅。IBM的DB2是第一个具备网上功能的多媒体关系数据库管理系统,支持包括Linux在内的一系列平台。B.中型数据库SQLServer是微软开发的数据库产品,主要支持windows平台。C.小型数据库mysql是一个小型关系型数据管理系统,开发者为瑞典mysqlAB公司,2005年被sun公司收购。开放源码。D.基于嵌入式Linux的数据库1.基于嵌入式linux的数据库主要有SQLite,Firbird,BerkeleyDB,extremeDB2.Firebird是关系型数据库,功能强大,支持存储过程、SQL兼容等3.SQLite关系型数据库,体积小,支持ACID(原子性、一致性、独立性及持久性Atomicity、Consistency、Isolation、Durability)事物。4.BerkeleyDB中并米有数据库服务器的概念,它的程序库直接连接到应用程序中5.extremeDB是内存数据库,运行效率高四、sqlite的介绍A.sqlite的源代码是C,其源代码完全开放。sqlite第一个Alpha版本诞生于2000年5月。他是一个轻量级的嵌入式数据库。B.sqlite有一下特性1零配置,无需安装和配置2储存在单一磁盘文件中的一个完整的数据库3数据库文件可以在不同字节顺序的机器间自由共享4支持数据库大小之2TB5足够小,全部源代码大致3万行C代码,250KB6比目前流行的大多数数据库对数据的操作要快C.sqlite数据库工作原理sqlite数据库采用模块化设计,由8个独立的模块构成,这些独立模块又构成了三个主要的子系统,模块将复杂的查询过程分解为细小的工作进行处理。sqlite主要由7个构件子系统(也就是模块)组成,这些模块被分割为两个部分:前端解析系统和后端引擎。前端:前端预处理应用程序传递过来的SQL语句和SQLite命令。对获取的编码分析,优化,并转换为后端能够执行的SQLite内部字节编码。前端可分为三个模块:1标示分析(Tokenizer)将输入的SQL语句分成标识符;2语法分析(Parser)解析器分析通过标识器产生的标识分析语句的结构,并且得到一颗语法树。解析器同时也包含了重构语法树的优化器,因此能够找到一颗产生一个高效的字节编码程序的语法树。3代码生成器(CodeGenerator)代码生成器遍历语法树,并且生成一个等价的字节编码程序前端实现了sqlite3_prepareAPI函数后端:后端是用来解释字节编码程序的引擎。该引擎做的才是真正的数据库处理工作。后端部分由四个模块组成:1虚拟机(VM)VM模块是一个内部字节编码语言的解释器。它通过执行字节编码语句来实现SQL语句的工作。它是数据库中数据的最终的操作者。它把数据库看成表和索引的集合,而表和索引则是一系列的元组或者记录。2B/B+树B/B+树模块把每一个元组集组织进一个一次排好序的树状数据结构中,表和索引被分别置于单独的B+和B树中。该模块帮助VM进行搜索,插入和删除树中的元组。它也帮助VM创建新的树和删除旧的树3页面调度程序(pager)页面调度程序模块在原始文件的上层实现了一个面向页面的数据库文件抽象。它管理B/B+树使用的内存内缓存(数据库页的),另外,他也管理文件的锁定,并用日志来实现事物的ACID属性。4操作系统交界面(systeminterface)操作系统界面模块提供了对应于不同本地操作系统的统一交界面后端实现了sqlite3_bind_*,sqlite3_setp,sqlite3_coloumn_*,sqlite3_reset和sqlite3_finalizeAPI函数。五、sqlite的一些手动操作语句和命令A.sqlite常用命令介绍1在终端下运行sqlite3*.db,出现如下提示符*.db是要打开的数据库文件。若该文件不存在,则自动创建。2显示所有命令sqlite.help3退出sqlite3sqlite.quit4显示当前打开的数据库文件sqlite.database5显示数据库中所有表名sqlite.tables6查看表的结构sqlite.schema注意:这些命令都是以.开头的。操作案例:(我这个数据库文件中已经创建好了表,后面将介绍如何创建和操作表)B.sqlite常用语句注意:每条语句都必须以;结尾。1创建新表sqlitecreatetable(f1type1,f2type2,…);例如:createtablepeople(id,name,age);2删除表sqlitedroptable例如:droptablepeople;3向表中添加新记录sqliteinsertintovalues(value1,value2,…);例如:insertintopeoplevalues(1,'A',10);insertintopeoplevalues(2,'B',13);insertintopeoplevalues(3,'C',9);insertintopeoplevalues(4,'C',15);insertintopeoplevalues(5,NULL,NULL);注意:字符串要用单引号括起来。4查询表中所有记录sqliteselect*from;例如:select*frompeople;4按指定条件查询表中记录sqliteselect*fromwhere;例如:在表中搜索名字是A的项所有信息select*frompeoplewherename='A';在表中搜索年龄=10并且=15的项的所有信息select*frompeoplewhereage=10andage=15;在表中搜索名字是C的项,显示其name和ageselectname,agefrompeoplewherename='C';显示表中的前2项所有信息select*frompeoplelimit2;显示以年龄排序表中的信息select*frompeopleorderbyage;6按指定条件删除表中记录sqlitedeletefromwhere例如:删除表中名字是'C'的项deletefrompoplewherename='C';7更新表中记录sqliteupdateset,…where;例如:将表中年龄是15并且ID是4项,名字改为CYGupdatepeoplesetname='cyg'whereid=4andage=15;8在表中添加字段sqlitealtertableaddcolumn;例如:在people表中添加一个addr字段altertablepeopleaddcolumnaddr;注意:(来自网络)今天在做数据库升级时,碰到要对原来数据库中一张表的一个字段名进行修改,但是用:altertabletablenamerenamecolumnoldColumnNametonewColumnName;始终不成功,后面查阅相关信息:SQLitesupportsalimitedsubsetofALTERTABLE.TheALTERTABLEcommandinSQLiteallowstheusertorenameatableortoaddanewcolumntoanexistingtable.Itisnotpossibletorenameacolumn,removeacolumn,oraddorremoveconstraintsfromatable.sqlite支持一个更改表内容的有限子集,就是说在sqlite更改表的命令中,只允许用户重命名表名或者增加多一个列到一个的表中。而重命名一个字段名和删除一个字段、或者增加和删除系统规定的参数这些操作是不可能的。解决办法:例如:在上面的操作过程中,我们在people表中新添加了一个字段addr,要删除这个字段,直接用sqlite的语句时无法完成的。我们可以这样干:A.将people表重命名为temp;B.重新创建people表;C.将temp表中的相应字段内容复制到people表中。D.删除temp表操作如下:A.altertablepeoplerenametotemp;B.createtablepeople(id,name,age);C.insertintopeopleselectid,name,agefromtemp;六、sqlite的一些常用API1sqlite里最常用到的是sqlite3*类型。从数据库打开开始,sqlite就要为这个类型准备好内存,直到数据库关闭,整个过程都需要用到这个类型。当数据库打开时开始,这个类型的变量就代表了你要操作的数据库,即句柄。2intsqlite3_open(char*path,sqlite3**db);功能:打开sqlite数据库path:数据库文件路径(如果不存在,则创建)db:指向sqlite句柄的指针返回值:如果是SQLITE_OK则表示操作正常。相关的返回值sqlite定义了一些宏。具体这些宏的含义可以参考sqlite3.h文件。3intsqlite3_close(sqlite3*db);功能:关闭sqlite数据库放回值:成功返回0,失败返回错误码4constchar*sqlite3_errmsg(sqlite3*db);返回值:返回错误信息案例:1.#includesqlite3.h2.#includeerrno.h3.#includestdlib.h4.#includestdio.h5.6.intmain(intargc,char*argv[])7.{8.sqlite3**db;9.intresult;10.11.if(argc2)12.{13.fprintf(stderr,usage:%sargv[1].\n,argv[0]);14.exit(EXIT_FAILURE);15.}16.17.result=sqlite3_open(argv[1],&db);18.if(result!=SQLITE_OK)19.{20.printf(Failtosqlite3open%s:%s.\n,argv[1],sqlite3_errmsg(db));21.exit(EXIT_FAILURE);22.}23.24.result=sqlite3_close(db);25.if(result!=0)26.{27.p
本文标题:Sqlite3数据库
链接地址:https://www.777doc.com/doc-3382001 .html