转自:http://blog.chinaunix.net/uid-26833883-id-3239313.html
一、数据库基本概念

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语句的工作。它是数据库中数据的最终的操作者。它把数据库看成表和索引的集合,而表和索引则是一系列的元组或者记录。
<2>B/B+树
B/B+树模块把每一个元组集组织进一个一次排好序的树状数据结构中,表和索引被分别置于单独的B+和B树中。该模块帮助VM进行搜索,插入和删除树中的元组。它也帮助VM创建新的树和删除旧的树
<3>页面调度程序(pager)
页面调度程序模块在原始文件的上层实现了一个面向页面的数据库文件抽象。它管理B/B+树使用的内存内缓存(数据库页的),另外,他也管理文件的锁定,并用日志来实现事物的ACID属性。
<4>操作系统交界面(system interface)
操作系统界面模块提供了对应于不同本地操作系统的统一交界面
后端实现了sqlite3_bind_*,sqlite3_setp,sqlite3_coloumn_*,sqlite3_reset和sqlite3_finalize API函数。
五、sqlite的一些手动操作语句和命令
A.sqlite常用命令介绍
<1>在终端下运行sqlite3 <*.db>,出现如下提示符

<*.db>是要打开的数据库文件。若该文件不存在,则自动创建。
<2>显示所有命令
sqlite> .help
<3>退出sqlite3
sqlite>.quit
<4>显示当前打开的数据库文件
sqlite>.database
<5>显示数据库中所有表名
sqlite>.tables

<6>查看表的结构
sqlite>.schema  <table_name>

注意:这些命令都是以 " .  "开头的。
操作案例:(我这个数据库文件中已经创建好了表,后面将介绍如何创建和操作表)

B.sqlite常用语句 
注意:每条语句都必须以";"结尾。
<1>创建新表
sqlite>create  table  <table_name>  (f1  type1, f2  type2,…);
例如:
create table  people(id,name,age);
<2>删除表
sqlite>drop  table  <table_name>
例如:
 drop table people;
<3>向表中添加新记录
  sqlite>insert  into  <table_name>  values (value1, value2,…);
例如:
   insert into people  values(1,'A',10);
        insert into people  values(2,'B',13);
        insert into people  values(3,'C',9);
        insert into people  values(4,'C',15);

        insert into people  values(5,NULL,NULL);
 注意: 字符串要用单引号括起来。
<4>查询表中所有记录
sqlite>select  *  from  <table_name>;
例如 :
select   *   from  people;
<4>按指定条件查询表中记录
sqlite>select  *  from  <table_name>  where  <expression>;
例如:
在表中搜索名字是A的项所有信息
  select  *  from  people  where  name='A';
在表中搜索年龄>=10并且<=15的项的所有信息
 select  *  from   people  where age>=10  and  age<=15;
在表中搜索名字是C的项,显示其name和age
 select name,age from people where name='C';
显示表中的前2项所有信息
 select  *  from  people  limit  2;
显示以年龄排序表中的信息
select * from people  order by age;
<6>按指定条件删除表中记录
sqlite>delete  from  <table_name>  where  <expression>

例如:
删除表中名字是'C'的项
 delete from pople  where name='C';
<7>更新表中记录
 sqlite>update  <table_name>  set  <f1=value1>, <f2=value2>…   where  <expression>;  
例如:
将表中年龄是15并且ID是4项,名字改为CYG
update  people set  name='cyg'  where  id=4 and  age=15;
<8>在表中添加字段
sqlite>alter table <table> add column <field> ;

例如:
在people表中添加一个addr字段
alter table  people add column addr;
 注意:(来自网络)
今天在做数据库升级时,碰到要对原来数据库中一张表的一个字段名进行修改,但是用:
alter table tablename rename column oldColumnName to newColumnName;
始终不成功,后面查阅相关信息:
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.
sqlite支持一个更改表内容的有限子集,就是说在sqlite更改表的命令中,只允许用户重命名表名或者增加多一个列到一个的表中。而重命名一个字段名和删除一个字段、或者增加和删除系统规定的参数这些操作是不可能的。
解决办法:
例如:在上面的操作过程中,我们在people表中新添加了一个字段addr,要删除这个字段,直接用sqlite的语句时无法完成的。
我们可以这样干:
A.将people表重命名为temp;
B.重新创建people表;
C.将temp表中的相应字段内容复制到people表中。
D.删除temp表
操作如下:
A.alter table people rename to temp;
B.create table people(id,name,age);
C.insert  into  people  select  id,name,age  from temp;
六、sqlite的一些常用API
<1>sqlite里最常用到的是sqlite3 *类型。从数据库打开开始,sqlite就要为这个类型准备好内存,直到数据库关闭,整个过程都需要用到这个类型。当数据库打开时开始,这个类型的变量就代表了你要操作的数据库,即句柄。
<2>int   sqlite3_open(char *path,sqlite3   **db);
功能:打开sqlite数据库
path:数据库文件路径(如果不存在,则创建)
db:指向sqlite句柄的指针
返回值:如果是SQLITE_OK则表示操作正常。相关的返回值sqlite定义了一些宏。具体这些宏的含义可以参考sqlite3.h文件。
<3>int   sqlite3_close(sqlite3  *db);
功能:关闭sqlite数据库
放回值:成功返回0,失败返回错误码
<4>const char *sqlite3_errmsg(sqlite3   *db);
返回值:返回错误信息
案例:

  1. #include <sqlite3.h>
  2. #include <errno.h>
  3. #include <stdlib.h>
  4. #include <stdio.h>
  5. int main(int argc,char *argv[])
  6. {
  7. sqlite3 **db;
  8. int result;
  9. if(argc < 2)
  10. {
  11. fprintf(stderr,"usage : %s argv[1].\n",argv[0]);
  12. exit(EXIT_FAILURE);
  13. }
  14. result = sqlite3_open(argv[1],&db);
  15. if(result != SQLITE_OK)
  16. {
  17. printf("Fail to sqlite3 open %s : %s.\n",argv[1],sqlite3_errmsg(db));
  18. exit(EXIT_FAILURE);
  19. }
  20. result = sqlite3_close(db);
  21. if(result != 0)
  22. {
  23. printf("Fail to sqlite3 close %s : %s.\n",argv[1],sqlite3_errmsg(db));
  24. exit(EXIT_FAILURE);
  25. }
  26. exit(EXIT_SUCCESS);
  27. }
<5>执行一条sql语句
typedef  int (*sqlite3_callback)(void *,int ,char **,char **);
int  sqlite3_exec
(
sqlite3   *db ,  
const  char *sql , 
sqlite3_callback  callback   ,
void  *arg,char  **errmsg 
);
a.第一个参数是前面sqlite3_open函数得到的指针。
b.第二个参数const  char   *sql是一条sql语句,以\0结尾。
c.第三个参数callbak是回调,当这条语句执行之后,sqlite3会去调用你提供的这个函数。
d.第四个参数void *是你提供的指针,你可以传递任何一个指针参数到这里,这个参数最终会传到回调函数里面,如果不需要传递指针给回调函数,可以填NULL。
e.第5个参数char  **errmsg是错误信息。注意是指针的指针。sqlite3里面有很多固定的错误信息。执行sqlite3_exec之后,执行失败是可以查阅这个指针;
例如:
char *errmsg;
调用sqlite3_exec,失败后printf("%s\n",errmsg)得到一串字符串信息,这串信息高诉你错在什么地方。sqlite3_exec函数通过修改你传入的指针的指针,把你提供的指针指向错误提示信息,这样sqlite3_exec函数外面就可以通过这个char *errmsg得到具体错误提示
说明:通常,sqlite3_callback和它后面的void *这两个位置都可以填NULL。填NULL表示你不需要回调。比如你做insert操作,做delete操作,就没有必要使用回调。而当你做select时,就要使用回调,因为sqlite3把数据查出来,得通过回调告诉你查出了什么数据。
返回值:成功返回0,失败返回错误码
exec的回调
typedef  int (*sqlite3_callback)(void  *para,int   n_column,char **column_value,char  **column_name);
a.通过para参数,你可以传入一些特殊的指针(比如类指针、结构指针),然后在这里面强制转换成对应的类型(这里面是void  *类型,必须强制转换成你的类型才可用)。然后操作这些数据。
b.n_column是这一条记录有多少个字段(即这条记录有多少列)。
c.char  **column_value是个关键值,查出来的数据都保存在这里,它实际上可以看做是一个一维的指针数组,每个元素都是一个char *值,是一个字段的内容(用字符串来表示,以\0结尾)。
d.char  **column_nam 跟column_value是对应的,表示这个字段的字段名称 。
//sqlite3的回调函数,sqlite每查到一条记录,就调用一次这个回调
int LoadMyInfo(void  *para,int  n_column,char  **column_value,char  ** column_name)
{
    //para是你在sqlite3_exec里传入的void  * 参数
    int     i;
    
    printf("记录包含%d个字段\n",n_column);
    for(i = 0;i < n_column;i ++)
    {
        printf("字段名 : %s  <->  字段值 : %s.\n",column_name[i],column_value[i]);
    }
    printf("--------------------------\n");
    
    return 0;
}
案例分析:

  1. #include <sqlite3.h>
  2. #include <stdio.h>
  3. #include <stdlib.h>
  4. #include <string.h>
  5. #define MAX 100
  6. typedef int (*sqlite3_callbak)(void *,int ,char **,char **);
  7. int ShowMyInfo(void *arg,int n_column,char **column_value,char **column_name)
  8. {
  9. int i = 0;
  10. for(i = 0;i < n_column;i ++)
  11. {
  12. printf("%s\t",column_name[i]);
  13. }
  14. printf("\n*************************************\n");
  15. for(i = 0;i < n_column;i ++)
  16. {
  17. printf("%s\t",column_value[i]);
  18. }
  19. printf("\n\n");
  20. return 0;
  21. }
  22. int exec_sql_string(char *sql_string,sqlite3 *db)
  23. {
  24. char *errmsg;
  25. if(sqlite3_exec(db,sql_string,ShowMyInfo,NULL,&errmsg) != 0)
  26. {
  27. fprintf(stderr,"Fail to exec sql(%s) : %s.\n",sql_string,errmsg);
  28. return -1;
  29. }
  30. return 0;
  31. }
  32. int main(int argc,char *argv[])
  33. {
  34. sqlite3 *db;
  35. int result;
  36. char sql_buf[MAX];
  37. if(argc < 2)
  38. {
  39. fprintf(stderr,"usage : %s argv[1].\n",argv[0]);
  40. exit(EXIT_FAILURE);
  41. }
  42. result = sqlite3_open(argv[1],&db);
  43. if(result != SQLITE_OK)
  44. {
  45. fprintf(stderr,"Fail to sqlite3_open %s : %s.\n",argv[1],sqlite3_errmsg(db));
  46. exit(EXIT_FAILURE);
  47. }
  48. while(1)
  49. {
  50. printf("sqlite >");
  51. fgets(sql_buf,sizeof(sql_buf),stdin);
  52. sql_buf[strlen(sql_buf) - 1] = '\0';
  53. if(strncmp(sql_buf,"quit",4) == 0)
  54. break;
  55. exec_sql_string(sql_buf,db);
  56. }
  57. result = sqlite3_close(db);
  58. if(result != 0)
  59. {
  60. fprintf(stderr,"Fail to sqlite3_open %s : %s.\n",argv[1],sqlite3_errmsg(db));
  61. exit(EXIT_FAILURE);
  62. }
  63. exit(EXIT_SUCCESS);
  64. }

运行结果:

<6>不使用回调函数执行SQL语句
int   sqlite3_get_table
(
sqlite3   *db,
const char  *sql,
char  ***resultp,
int  *nrow,
int  *ncolumn,
char   **errmsg
);
功能:执行sql操作
db  :   数据库句柄
sql  :  sql语句
resultp  : 用来指向sql执行结果的指针
nrow  :  满足条件的记录的数目
ncolumn  :  每条记录包含的字段数目
注意:
从第0索引到第ncolumn-1索引都是字段的名称
从第ncolumn索引开始,后面都是字段的值
errmsg  :  错误信息指针的地址
返回值:成功返回0,失败返回错误码
实例:

  1. #include <sqlite3.h>
  2. #include <stdio.h>
  3. #include <stdlib.h>
  4. #include <string.h>
  5. #define MAX 100
  6. int exec_sql_string(char *sql_string,sqlite3 *db)
  7. {
  8. char *errmsg,**dbResult;
  9. int nRow,nColumn;
  10. int result,i,j,index;
  11. result = sqlite3_get_table(db,sql_string,&dbResult,&nRow,&nColumn,&errmsg);
  12. if(0 != result){
  13. fprintf(stderr,"Fail to exec sql(%s) : %s.\n",sql_string,errmsg);
  14. return -1;
  15. }
  16. //字段名字
  17. for(j = 0;j < nColumn;j ++)
  18. {
  19. printf("%s\t",dbResult[j]);
  20. }
  21. printf("\n");
  22. index = nColumn;//从它开始是字段对应的值
  23. for(i = 0;i < nRow;i ++)//查询到总共记录个数
  24. {
  25. for(j = 0;j < nColumn;j ++)
  26. {
  27. printf("%s\t",dbResult[index]);
  28. index ++;
  29. }
  30. printf("\n");
  31. }
  32. //释放查询结果所分配的内存
  33. sqlite3_free_table(dbResult);
  34. return 0;
  35. }
  36. int main(int argc,char *argv[])
  37. {
  38. sqlite3 *db;
  39. int result;
  40. char sql_buf[MAX];
  41. if(argc < 2)
  42. {
  43. fprintf(stderr,"usage : %s argv[1].\n",argv[0]);
  44. exit(EXIT_FAILURE);
  45. }
  46. result = sqlite3_open(argv[1],&db);
  47. if(result != SQLITE_OK)
  48. {
  49. fprintf(stderr,"Fail to sqlite3_open %s : %s.\n",argv[1],sqlite3_errmsg(db));
  50. exit(EXIT_FAILURE);
  51. }
  52. while(1)
  53. {
  54. printf("sqlite >");
  55. fgets(sql_buf,sizeof(sql_buf),stdin);
  56. sql_buf[strlen(sql_buf) - 1] = '\0';
  57. if(strncmp(sql_buf,"quit",4) == 0)
  58. break;
  59. exec_sql_string(sql_buf,db);
  60. }
  61. result = sqlite3_close(db);
  62. if(result != 0)
  63. {
  64. fprintf(stderr,"Fail to sqlite3_open %s : %s.\n",argv[1],sqlite3_errmsg(db));
  65. exit(EXIT_FAILURE);
  66. }
  67. exit(EXIT_SUCCESS);
  68. }

运行结果:

sqlite3的基本操作相关推荐

  1. Sqlite3 数据库基本操作

    Sqlite3 数据库基本操作 1.sqlite3命令 **2.sqlite3编程接口:** 3.事务:一个或多个更改数据库的扩展 4.like和glob子句: 5.limit 和 offset 6. ...

  2. sqlite3之基本操作(二)

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! Python自带一个轻量级的关系型数据库SQLite.这一数据库使用SQL语言.S ...

  3. python创建sqlite3数据库_Python之Sqlite3数据库基本操作

    在一些小的应用中,难免会用到数据库,Sqlite数据库以其小巧轻便,无需安装,移植性好著称,本文主要以一个简单的小例子,简述Python在Sqlite数据库方面的应用,仅供学习分享使用,如有不足之处, ...

  4. ios中SQLite3的基本操作

    本文转自:http://blog.csdn.net/eduora_meimei/article/details/24299133 iOS关于sqlite3操作 iPhone中支持通过sqlite3来访 ...

  5. windows下sqlite3的基本操作

    1.下载命令行,并安装,立即下载>>: 2.创建一个数据库: 3.创建一张表: 4.插入.查询.更新.删除行记录:   5.事务相关: begin transaction[name]; . ...

  6. 08.QT中sqlite3数据库基本操作

    Qt版本数据库操作 1 创建项目时选择sql模块 2 简易效果图如下 3 代码如下图所示 #include "SqliteDemo.h" #include <QtSql/QS ...

  7. 浅显易懂 SQLite3 笔记(01)— SQLite3简介及基本操作

    文章目录 前言 一.SQLite数据库 1.什么是SQLite? 2.为什么要用SQLite? 3.如何使用SQLite? 二.SQLite语言及基本操作 1.SQLite命令 2.SQLite类型 ...

  8. SQLite3基本使用从shell到python

    SQLite是一个轻量级的关系型数据库,在訪问量不超过10万PV的中小站点中使用绰绰有余. 并且使用方便,接口简单,以下从命令行和python接口双方面介绍SQLite3的基本操作. 在linux终端 ...

  9. C语言-打卡机(sqlite数据库、多线程)

    C语言-打卡机 一.功能 1.上班打卡 2.下班打卡 3.设置每日工作时长 4.测试需要6s=1h 5.弹性打卡制 6.周报 二.整体构思 三.自定义时间 四.Sqlite3数据库基本操作(增删改查) ...

最新文章

  1. MVC架构接收jsp页面传值
  2. 270 扩展固态硬盘_游戏人的扩展坞应该是怎样?
  3. 吴恩达深度学习笔记 2.6~2.9 logistic中的梯度下降
  4. 【Qt教程】1.3 - Qt5 工程文件的功能解读、快捷键
  5. [转载] python sorted 使用cmp函数时候注意cmp需要传入两个参数,传入两个参数机制的分析
  6. js实现键盘按键映射
  7. UPC6615: Snuke Festival
  8. gst-launch-1.0在Linux下的命令
  9. 微信WIFI小程序开发
  10. 版本 87.0.4280.66_iOS 14.2 Beta 2发布,修复闪退与优化改进
  11. 苹果手机相机九宫格怎么设置_用苹果手机拍照,这3个媲美单反的设置不会用,就别说自己用苹果...
  12. Java学习系列之抽象类和接口的区别和联系
  13. SCX-4521F一体机MAC驱动
  14. 基于生态农业的电子商务微信小程序毕业设计(论文)
  15. 【172. 阶乘后的零】
  16. 【服务器数据恢复】RAID5多块硬盘离线但是热备盘未激活导致RAID崩溃的数据恢复案例
  17. 如何查看windows 10 神州网信政府版的版本信息
  18. piinyin4j的使用 把中文转成拼音
  19. 京东低代码平台:水滴表单联动可视化配置的实现与思考
  20. 数据结构与算法之链表(Java版)

热门文章

  1. 阿里云胡晓明:数据智能将为城市生活带来真正价值
  2. SpringMVC视图解析器(转)
  3. TOUGHRADIUS 项目介绍
  4. 求 s=a+aa+ aaa+ aaaa +aaaaa+........的值,a是从键盘输入的,项数也为键盘输入
  5. 关于Android错误 View requires API level 14 (current...
  6. 一道C#类型转换的思考题
  7. 使用use index优化sql查询
  8. Stimulsoft reports .net中创建变量
  9. [转]ASP中ActiveX控件的内嵌及调用
  10. h5页 点击返回时关闭_在微信、支付宝、百度钱包实现点击返回按钮关闭当前页面和窗口...