一、打开数据库
int sqlite3_open( 文件名, sqlite3 ** );
需要传入两个参数,一是数据库文件名,比如:"/home/linux/test.db"
二是 sqlite3 ** ,实现定义好的,具体结构可以不用管
二、关闭数据库
int sqlite3_close(sqlite3 *);
关闭之前打开的数据库
三、执行sql语句
分为回调函数执行和不使用回调函数执行两类
含有回调函数的:
int sqlite3_exec(sqlite3*, const char *sql, sqlite3_callback, void *, char **errmsg );
第1个参数是前面open函数得到的指针
第2个参数const char *sql 是一条 sql 语句,以/0结尾。
第3个参数sqlite3_callback 是回调,当这条语句执行之后,sqlite3会去调用你提供的这个函数。
第4个参数void * 是你所提供的指针,你可以传递任何一个指针参数到这里,这个参数最终会传到回调函数里面,如果不需要传递指针给回调函数,可以填NULL。
第5个参数char ** errmsg 是错误信息。注意是指针的指针。sqlite3里面有很多固定的错误信息。执行 sqlite3_exec 之后,执行失败时可以查阅这个指针(直接 printf( “%s/n”,errmsg))得到一串字符串信息,这串信息告诉你错在什么地方。sqlite3_exec 函数通过修改你传入的指针的指针,把你提供的指针指向错误提示信息,这样sqlite3_exec函数外面就可以通过这个 char*得到具体错误提示。
说明:通常,sqlite3_callback 和它后面的 void * 这两个位置都可以填 NULL。填NULL表示你不需要回调。比如你做 insert 操作,做 delete 操作,
就没有必要使用回调。而当你做select 时,就要使用回调,因为 sqlite3 把数据查出来,得通过回调告诉你查出了什么数据。
(具体用法见下面链接的实例1)
不含回调函数的:
虽然回调显得代码整齐,但有时候你还是想要非回调的 select 查询。这可以通过sqlite3_get_table 函数做到。
int sqlite3_get_table(sqlite3*, const char *sql, char ***resultp, int *nrow, int *ncolumn, char **errmsg );
第1个参数不再多说,看前面的例子。
第2个参数是 sql 语句,跟 sqlite3_exec 里的 sql 是一样的。是一个很普通的以/0结尾的char *字符串。
第3个参数是查询结果,它依然一维数组(不要以为是二维数组,更不要以为是三维数组)。它内存布局是:第一行是字段名称,后面是紧接着是每个字段的值。
第4个参数是查询出多少条记录(即查出多少行)。
第5个参数是多少个字段(多少列)。
第6个参数是错误信息,跟前面一样。
(具体用法见下面链接的实例2)