SQLITE 操作入门
SQLITE操作入门
sqlite提供的是一些C函数接口,你可以用这些函数操作数据库。通过使用这些接口,传递一些标准sql语句(以char*类型)给sqlite函数,sqlite就会为你操作数据库。 sqlite跟MS的access一样是文件型数据库,就是说,一个数据库就是一个文件,此数据库里可以建立很多的表,可以建立索引、触发器等等,但是,它实际上得到的就是一个文件。备份这个文件就备份了整个数据库。 sqlite不需要任何数据库引擎,这意味着如果你需要sqlite来保存一些用户数据,甚至都不需要安装数据库(如果你做个小软件还要求人家必须装了sqlserver才能运行,那也太黑心了)。 下面开始介绍数据库基本操作。 1基本流程 (1)关键数据结构 sqlite里最常用到的是sqlite3*类型。从数据库打开开始,sqlite就要为这个类型准备好内存,直到数据库关闭,整个过程都需要用到这个类型。当数据库打开时开始,这个类型的变量就代表了你要操作的数据库。下面再详细介绍。 (2)打开数据库 intsqlite3_open(文件名,sqlite3**); 用这个函数开始数据库操作。 需要传入两个参数,一是数据库文件名,比如:c:DongChunGuang_Database.db。 文件名不需要一定存在,如果此文件不存在,sqlite会自动建立它。如果它存在,就尝试把它当数据库文件来打开。 sqlite3**参数即前面提到的关键数据结构。这个结构底层细节如何,你不要关它。 函数返回值表示操作是否正确,如果是SQLITE_OK则表示操作正常。相关的返回值sqlite定义了一些宏。具体这些宏的含义可以参考sqlite3.h文件。里面有详细定义(顺便说一下,sqlite3的代码注释率自称是非常高的,实际上也的确很高。只要你会看英文,sqlite可以让你学到不少东西)。 下面介绍关闭数据库后,再给一段参考代码。 (3)关闭数据库 intsqlite3_close(sqlite3*); 前面如果用sqlite3_open开启了一个数据库,结尾时不要忘了用这个函数关闭数据库。 下面给段简单的代码: extern"C" { #include"./sqlite3.h" }; intmain(int,char**) { sqlite3*db=NULL;//声明sqlite关键结构指针 intresult;
打开数据库 需要传入db这个指针的指针,因为sqlite3_open函数要为这个指针分配内存,还要让db指针指向这个内存区 result=sqlite3_open(“c:Dcg_database.db”,&db); if(result!=SQLITE_OK) { 数据库打开失败 return-1; } 数据库操作代码 …
数据库打开成功 关闭数据库 sqlite3_close(db); return0; } 这就是一次数据库操作过程。
2SQL语句操作
本节介绍如何用sqlite执行标准sql语法。
(1)执行sql语句 intsqlite3_exec(sqlite3*,constchar*sql,sqlite3_callback,255)">void*,255)">char**errmsg); 这就是执行一条sql语句的函数。 第1个参数不再说了,是前面open函数得到的指针。说了是关键数据结构。 第2个参数constchar*sql是一条sql语句,以 |