1.安装数据库
Linux 下安装sqlite3 需要两个个命令 即可:
(1)sudo apt-get install sqlite
(2)apt-get install libsqlite3-dev
2.相关函数
1. sqlite3_open 用来打开一个数据库
#include <sqlite3.h>
int sqlite3_open(const char *dbname, sqlite3 **db)
第一个参数dbname:数据库的名称
第二个参数 db:数据库的句柄
2.sqlite3_close 关闭一个数据库
int sqlite3_close(sqlite3 *db)
3.sqlite3_exec 用来执行sqlite3 语句
int sqlite_exec(sqlite *db, const char *sql,int (* callback)(void *int, char **, char **),void *, char **errmsg);
第一个参数db:与之前相同;
第二个参数sql:SQL语句;以\0结尾。
第三个参数callback:回调函数;当这条语句执行之后,sqlite3会去调用你提供的这个函数。通常设为NULL。
第四个参数void*是你所提供的指针,你可以传递任何一个指针参数到这里,这个参数最终会传到回调函数里面,如果不需要传递指针给回调函数,可以填NULL。
第五个参数char** errmsg 是错误信息。
说明:通常,sqlite3_callback和它后面的void*这两个位置都可以填NULL。填NULL表示你不需要回调。比如你做insert 操作,做delete操作,就没有必要使用回调。而当你做select 时,就要使用回调,因为sqlite3 把数据查出来,得通过回调告诉你查出了什么数据。虽然回调显得代码整齐,但有时候你还是想要非回调的select
查询。这可以通过sqlite3_get_table 函数做到。
4.sqlte3_get_table 执行sql的查询功能
在int sqlite3_get_table(sqlite3 *db, const char *zSql,char **pazResult, int *pnRow,int *pnColumn);
第一个参数db:数据库句柄
第二个参数zSql:sqlite3的语句,跟sqlite3_exec 里的sql 是一样的。是一个很普通的以\0结尾的char*字符串。
第三个参数pazResult:查询的结果,它依然一维数组(不要以为是二维数组,更不要以为是三维数组)。它内存布局是:字段名称,后面是紧接着是每个字段值。
第四个参数pnRow:结果集的列数,即查出多少行
第五个参数errmsg:错误信息
注意:如果提供了errmsg,用来创建错误消息的内存是在堆上分布的。 故在调用后,应该检查一下是否为null值,如果有错误发生,使用sqlite3_free()释放errmsg占用的内存。
3.代码实例
3.1创建一个数据库
#include <stdio.h>
#include <string.h>
#include <sqlite3.h>
#include <errno.h>
#include <stdlib.h>
int main(int argc, char **argv)
{
sqlite3 *db=NULL;
int rc = -1