转自:http://blog.chinaunix.net/uid-26833883-id-3239313.html
@H_301_3@
一、数据库基本概念
@H_301_3@
@H_301_3@
A.数据(Data)
@H_301_3@
能够输入计算机并能被计算机程序识别和处理的信息集合。
@H_301_3@
B.数据库(Database)
@H_301_3@
数据库是在数据库管理系统管理和控制之下,存放在存储介质上的数据集合。
@H_301_3@
注意:数据库管理系统(DataBase Mangement System) --DBMMS
@H_301_3@
C.数据库管理系统(DBMS)
@H_301_3@
DBMS是数据库系统中对数据进行统一管理和控制的软件系统
@H_301_3@
(1)数据库定义功能 (Data Definition)
@H_301_3@
(2)数据库操纵功能 (Data Manpulation)
@H_301_3@
(3)数据库运行控制功能 (Data Control)
@H_301_3@
(4)数据通信功能(Data Communication)
@H_301_3@
即 为应用程序提供的访问接口
@H_301_3@
(5)支持存取海量数据(Mass Data)
@H_301_3@
二、文件管理和数据库管理
@H_301_3@
A.文件管理阶段
@H_301_3@
优点 : (i)数据可长期保存
@H_301_3@
(ii)能存储大量数据
@H_301_3@
缺点: (i)数据冗余度(redundancy)、数据一致性(consistency)、完整性(integrity)难以维持
@H_301_3@
(ii)数据与程序缺乏高度独立性
@H_301_3@
B.数据库系统阶段
@H_301_3@
(i)数据组织结构化
@H_301_3@
(ii)数据冗余度比较小,易扩充
@H_301_3@
(iii)具有较高的数据与程序之间的独立性
@H_301_3@
(iv)统一的数据控制
@H_301_3@
三、常用的数据库介绍
@H_301_3@
A.大型数据库
@H_301_3@
Oracle公司是最早开发关系数据库的厂商之一,其产品支持最广泛的操作系统平台。目前Oracle关系数据库产品的市场占有率名列前茅。
@H_301_3@
IBM的DB2是第一个具备网上功能的多媒体关系数据库管理系统,支持包括Linux在内的一系列平台。
@H_301_3@
B.中型数据库
@H_301_3@
sqlServer是微软开发的数据库产品,主要支持windows平台。
@H_301_3@
C.小型数据库
@H_301_3@
MysqL是一个小型关系型数据管理系统,开发者为瑞典MysqL AB公司,2005年被sun公司收购。开放 源码。
@H_301_3@
D.基于嵌入式Linux的数据库
@H_301_3@
<1>.基于嵌入式linux的数据库主要有sqlite,Firbird,Berkeley DB,extremeDB
@H_301_3@
<2>.Firebird是关系型数据库,功能强大,支持存储过程、sql兼容等
@H_301_3@
<3>.sqlite关系型数据库,体积小,支持 ACID(原子性、一致性、独立性及持久性 Atomicity、Consistency、Isolation、Durability)事物。
@H_301_3@
<4>.Berkeley DB中并米有数据库服务器的概念,它的程序库直接连接到应用程序中
@H_301_3@
<5>.extremeDB是内存数据库,运行效率高
@H_301_3@
四、sqlite的介绍
@H_301_3@
A.sqlite的源代码是C,其源代码完全开放。sqlite第一个Alpha版本诞生于2000年5月。他是一个轻量级的嵌入式数据库。
@H_301_3@
B.sqlite有一下特性
@H_301_3@
<1>零配置,无需安装和配置
@H_301_3@
<2>储存在单一磁盘文件中的一个完整的数据库
@H_301_3@
<3>数据库文件可以在不同字节顺序的机器间自由共享
@H_301_3@
<4>支持数据库大小之2TB
@H_301_3@
<5>足够小,全部源代码大致3万行C代码,250KB
@H_301_3@
<6>比目前流行的大多数数据库对数据的操作要快
@H_301_3@
C.sqlite数据库工作原理
@H_301_3@
sqlite数据库采用模块化设计,由8个独立的模块构成,这些独立模块又构成了三个主要的子系统,模块将复杂的查询过程分解为细小的工作进行处理。
sqlite主要由7个构件子系统(也就是模块)组成,这些模块被分割为两个部分:
@H_301_3@
前端解析系统和后端引擎。
@H_301_3@
@H_301_3@
@H_301_3@
前端:
@H_301_3@
@H_301_3@
@H_301_3@
前端预处理应用程序传递过来的sql语句和sqlite命令。对获取的编码分析,优化,并转换 为后端能够执行的sqlite内部字节编码。前端可分为三个模块:
@H_301_3@
@H_301_3@
@H_301_3@
<1>标示分析(Tokenizer)
@H_301_3@
@H_301_3@
@H_301_3@
将输入的sql语句分成标识符;
@H_301_3@
@H_301_3@
@H_301_3@
<2>语法分析(Parser)
@H_301_3@
@H_301_3@
@H_301_3@
解析器分析通过标识器产生的标识分析语句的结构,并且得到一颗语法树。解析器同时也包含了重构语法树的优化器,因此能够找到一颗产生一个高效的字节编码程序的语法树。
@H_301_3@
@H_301_3@
@H_301_3@
<3>代码生成器(Code Generator)
@H_301_3@
@H_301_3@
@H_301_3@
代码生成器遍历语法树,并且生成一个等价的字节编码程序
@H_301_3@
@H_301_3@
@H_301_3@
前端实现了sqlite3_prepare API函数
@H_301_3@
@H_301_3@
@H_301_3@
后端:
@H_301_3@
@H_301_3@
@H_301_3@
后端是用来解释字节编码程序的引擎。该引擎做的才是真正的数据库处理工作。后端部分由四个模块组成:
@H_301_3@
@H_301_3@
@H_301_3@
<1>虚拟机(VM)
@H_301_3@
@H_301_3@
@H_301_3@
VM模块是一个内部字节编码语言的解释器。它通过执行字节编码语句来实现sql语句的工作。它是数据库中数据的最终的操作者。它把数据库看成表和索引的集合,而表和索引则是一系列的元组或者记录。
@H_301_3@
@H_301_3@
@H_301_3@
<2>B/B+树
@H_301_3@
@H_301_3@
@H_301_3@
B/B+树模块把每一个元组集组织进一个一次排好序的树状数据结构中,表和索引被分别置于单独的B+和B树中。该模块帮助VM进行搜索,插入和删除树中的元组。它也帮助VM创建新的树和删除旧的树
@H_301_3@
@H_301_3@
@H_301_3@
<3>页面调度程序(pager)
@H_301_3@
@H_301_3@
@H_301_3@
页面调度程序模块在原始文件的上层实现了一个面向页面的数据库文件抽象。它管理B/B+树使用的内存内缓存(数据库页的),另外,他也管理文件的锁定,并用日志来实现事物的ACID属性。
@H_301_3@
@H_301_3@
@H_301_3@
<4>操作系统交界面(system interface)
@H_301_3@
@H_301_3@
@H_301_3@
操作系统界面模块提供了对应于不同本地操作系统的统一交界面
@H_301_3@
@H_301_3@
@H_301_3@
后端实现了sqlite3_bind_*,sqlite3_setp,sqlite3_coloumn_*,sqlite3_reset和sqlite3_finalize API函数。
@H_301_3@
@H_301_3@
@H_301_3@
五、sqlite的一些手动操作语句和命令
@H_301_3@
@H_301_3@
@H_301_3@
A.sqlite常用命令介绍
@H_301_3@
@H_301_3@
@H_301_3@
<1>在终端下运行sqlite3 <*.db>,出现如下提示符
<*.db>是要打开的数据库文件。若该文件不存在,则自动创建。
@H_301_3@
@H_301_3@
@H_301_3@
<2>显示所有命令
@H_301_3@
sqlite> .help
@H_301_3@
@H_301_3@
@H_301_3@
<3>退出sqlite3
@H_301_3@
sqlite>.quit
@H_301_3@
@H_301_3@
@H_301_3@
<4>显示当前打开的数据库文件
@H_301_3@
sqlite>.database
@H_301_3@
@H_301_3@
@H_301_3@
<5>显示数据库中所有表名
@H_301_3@
sqlite>.tables
@H_301_3@
@H_301_3@
@H_301_3@
@H_301_3@
<6>查看表的结构
@H_301_3@
sqlite>.schema <table_name>
@H_301_3@
@H_301_3@
@H_301_3@
@H_301_3@
@H_301_3@
@H_301_3@
注意:这些命令都是以 " . "开头的。
@H_301_3@
@H_301_3@
@H_301_3@
操作案例:(我这个数据库文件中已经创建好了表,后面将介绍如何创建和操作表)
B.sqlite常用语句
@H_301_3@
@H_301_3@
@H_301_3@
注意:每条语句都必须以";"结尾。
@H_301_3@
@H_301_3@
@H_301_3@
<1>创建新表
@H_301_3@
sqlite>create table <table_name> (f1 type1,f2 type2,…);
@H_301_3@
例如:
@H_301_3@
create table people(id,name,age);
@H_301_3@
@H_301_3@
@H_301_3@
<2>删除表
@H_301_3@
sqlite>drop table <table_name>
@H_301_3@
例如:
@H_301_3@
drop table people;
@H_301_3@
@H_301_3@
@H_301_3@
<3>向表中添加新记录
@H_301_3@
sqlite>insert into <table_name> values (value1,value2,…);
@H_301_3@
例如:
@H_301_3@
insert into people values(1,'A',10);
@H_301_3@
insert into people values(2,'B',13);
@H_301_3@
insert into people values(3,'C',9);
@H_301_3@
insert into people values(4,15);
@H_301_3@
@H_301_3@
insert into people values(5,NULL,NULL);
@H_301_3@
注意: 字符串要用单引号括起来。
@H_301_3@
@H_301_3@
@H_301_3@
<4>查询表中所有记录
@H_301_3@
sqlite>select * from <table_name>;
@H_301_3@
例如 :
@H_301_3@
select * from people;
@H_301_3@
@H_301_3@
@H_301_3@
<4>按指定条件查询表中记录
@H_301_3@
sqlite>select * from <table_name> where <expression>;
@H_301_3@
例如:
@H_301_3@
在表中搜索名字是A的项所有信息
@H_301_3@
select * from people where name='A';
@H_301_3@
@H_301_3@
在表中搜索年龄>=10并且<=15的项的所有信息
@H_301_3@
select * from people where age>=10 and age<=15;
@H_301_3@
@H_301_3@
在表中搜索名字是C的项,显示其name和age
@H_301_3@
select name,age from people where name='C';
@H_301_3@
@H_301_3@
@H_301_3@
显示表中的前2项所有信息
@H_301_3@
select * from people limit 2;
@H_301_3@
@H_301_3@
显示以年龄排序表中的信息
@H_301_3@
select * from people order by age;
@H_301_3@
@H_301_3@
<6>按指定条件删除表中记录
@H_301_3@
@H_301_3@
sqlite>delete from <table_name> where <expression>
@H_301_3@
@H_301_3@
@H_301_3@
例如:
@H_301_3@
删除表中名字是'C'的项
@H_301_3@
delete from pople where name='C';
@H_301_3@
@H_301_3@
@H_301_3@
<7>更新表中记录
@H_301_3@
@H_301_3@
@H_301_3@
sqlite>update <table_name> set <f1=value1>,<f2=value2>… where <expression>;
@H_301_3@
@H_301_3@
例如:
@H_301_3@
将表中年龄是15并且ID是4项,名字改为CYG
@H_301_3@
update people set name='cyg' where id=4 and age=15;
@H_301_3@
@H_301_3@
@H_301_3@
<8>在表中添加字段
@H_301_3@
@H_301_3@
sqlite>alter table <table> add column <field> ;
@H_301_3@
@H_301_3@
@H_301_3@
@H_301_3@
例如:
@H_301_3@
在people表中添加一个addr字段
@H_301_3@
alter table people add column addr;
@H_301_3@
@H_301_3@
注意:(来自网络)
@H_301_3@
@H_301_3@
今天在做数据库升级时,碰到要对原来数据库中一张表的一个字段名进行修改,但是用: @H_301_3@alter table tablename rename column oldColumnName to newColumnName; @H_301_3@
@H_301_3@始终不成功,后面查阅相关信息: @H_301_3@sqlite supports a limited subset of ALTER TABLE. The ALTER TABLE command in sqlite allows the user to rename a table or to add a new column to an existing table. It is not possible to rename a column,remove a column,or add or remove constraints from a table. @H_301_3@
@H_301_3@sqlite支持一个更改表内容的有限子集,就是说在sqlite更改表的命令中,只允许用户重命名表名或者增加多一个列到一个的表中。而重命名一个字段名和删除一个字段、或者增加和删除系统规定的参数这些操作是不可能的。 @H_301_3@
@H_301_3@解决办法: @H_301_3@
@H_301_3@例如:在上面的操作过程中,我们在people表中新添加了一个字段addr,要删除这个字段,直接用sqlite的语句时无法完成的。 @H_301_3@我们可以这样干: @H_301_3@A.将people表重命名为temp; @H_301_3@B.重新创建people表; @H_301_3@C.将temp表中的相应字段内容复制到people表中。 @H_301_3@D.删除temp表 @H_301_3@
@H_301_3@操作如下: @H_301_3@A.alter table people rename to temp; @H_301_3@B.create table people(id,age); @H_301_3@C.insert into people select id,age from temp; @H_301_3@
@H_301_3@六、sqlite的一些常用API @H_301_3@
@H_301_3@<1>sqlite里最常用到的是sqlite3 *类型。从数据库打开开始,sqlite就要为这个类型准备好内存,直到数据库关闭,整个过程都需要用到这个类型。当数据库打开时开始,这个类型的变量就代表了你要操作的数据库,即句柄。 @H_301_3@