sqlite3学习笔记

c语言 API接口

打开数据库

sqlite3_open_v2() 、sqlite3_open() 、sqlite3_open16()

int sqlite3_open_v2(
  const char * filename ,   //数据库名
  sqlite3 * ppDb ,          //数据库句柄
  int flags ,                   //对数据库的操作权限
  const char * zVfs             //允许调用去重写默认的操作系统接口sqlite3_vfs方法
);

数据库成功打开则返回SQLITE_OK,否则返回错误码。
若数据库不存在,且flags包含SQLITE_OPEN_CREATE,则会创建新数据库。

语句操作

int sqlite3_prepare_v2(         //将sql语句转换为准备语句
  sqlite3*db,               //数据库句柄
  const char*zSql,              //sql语句
  int nByte,                    //如果nByte小于0,则函数取出zSql中从开始到第一个0终止符的内容;
  //如果nByte不是负的,那么它就是这个函数能从zSql中读取的字节数的最大值。
  //如果nBytes非负,zSql在第一次遇见’/000/或’u000’的时候终止
  sqlite3_stmt **ppStmt,        // 返回的状态句柄
  const char**pzTail            //上面提到zSql在遇见终止符或者是达到设定的nByte之后结束,
  //假如zSql还有剩余的内容,那么这些剩余的内容被存放到pZTail中,不包括终止符
);

int sqlite3_exec(
  sqlite3 *db,                        /* An open database 数据库句柄  */
  const charchar *sql,                 /* SQL to be evaluated 要执行的操作  */
  int (*callback)(void*,int,char**,char**),  /* Callback function 回调函数的指针*/  
  voidvoid *,                        /* 1st argument to callback 传给回调函数的参数  */
  charchar **errmsg                  /* Error msg written here  错误信息*/
);

sqlite3_get_table(
  sqlite3 *db,            /* An open database 数据库句柄*/
  const char *zSql,       /* SQL to be evaluated 要执行的操作*/
  char ***pazResult,      /* Results of the query 执行结果,一维数组*/
  int *pnRow,           /* Number of result rows written here 行数*/
  int *pnColumn,        /* Number of result columns written here 列数*/
  char **pzErrmsg       /* Error msg written here 错误信息*/
);

int sqlite3_column_count(   //计算prepare函数返回结果的列数
sqlite3_stmt **ppStmt
);

int sqlite3_column_int(  //step执行完后的结果集中返回指定列的值
  sqlite3_stmt **ppStmt,//状态句柄
  int col  //想要返回列的索引值
};

int sqlite3_step(       //执行由前面sqlite3_prepare创建的准备语句。
//这个语句执行到结果的第一行可用的位置。
//继续前进到结果的第二行的话,只需再次调用sqlite3_setp()。
//继续调用sqlite3_setp()直到这个语句完成
  sqlite3_stmt **ppStmt  //prepare返回的状态句柄
);

int sqlite3_finalize(//销毁前面被sqlite3_prepare创建的准备语句,
//每个准备语句都必须使用这个函数去销毁以防止内存泄露。
  sqlite3_stmt *pStmt  //prepare返回的状态句柄
);

int sqlite3_reset(
   sqlite3_stmt *pStmt  //prepare返回的状态句柄
);
//如果之前没有执行sqlite3_step,
//或者执行了之后返回SQLITE_DONE、SQLITE_OK、SQLITE_ROW中的一个
//则调用sqlite3_reset会将stmt返回到prepare刚执行之后的状态
//若调用了step函数并且出错,则使用reset会返回一个错误值
绑定值

(为啥要绑定?)
在一条带参数的prepare之后,step之前,可以给每一个stmt参数绑定一个指定的值。如果一条语句已经调用step执行了,就不能绑定值了,除非这条语句被重置。
一共有9个bind函数,所有这些函数的第1个参数和第2个参数的返回值都是相同的。第一个参数是指向sqlite3_stmt的指针,第二个参数是要绑定的值的索引值,从1开始,第三个参数是要给stmt绑定的值。第四个参数(有的话)代表第三个参数“绑定值”的字节长度。第五个参数(有的话)是指向内存管理回调函数的指针。
以上9个函数,如果执行成功则返回SQLITE_OK,否则返回错误码

int sqlite3_bind_init(sqlite3_stmt *, int, int)//绑定一个32位有符号整型值
int sqlite3_bind_blob(sqlite3_stmt*,const void *,int, void*(void *))
//绑定任意长度的blob类型的二进制数据
//blob:二进制大对象,相当于可以存储大量二进制数据的容器
int sqlite3_bind_text(sqlite3_stmt*, int, const char*, int n, void(*)(void*));
//绑定一个任意长度的UTF-8编码的文本值,第4个参数是字节长度,注意不是字符长度。
//如果给第4个参数传递负值,SQlite就会自动计算绑定值的字节长度(不包括NULL结尾符)
//第五个参数为一个函数指针,SQLITE3执行完操作后回调此函数,通常用于释放字符串占用的内存
//第五个参数为SQLITE_STATIC时,表示绑定的字符串为常量
//第五个参数为SQLITE_TRANSIENT时,表示需要拷贝一份字符串

其他函数见:
https://blog.csdn.net/northcan/article/details/7235519

sqlite操作

PRAGMA语句是SQLITE数据的SQL扩展,是它独有的特性,主要用于修改SQLITE库或者内数据查询的操作
详细用法参见:
http://iihero.iteye.com/blog/1189633

limit

select * from tablename where ... order by ... limit m offset n
select * from tablename where ... order by ... limit n,m
//m表示要显示多少条记录,n表示要跳过多少记录,
//limit 3 offset 5 表示从第6条开始显示3条记录,即第6、7、8条

order by

select * from tablename order by asc//升序
select * from tablename order by desc//降序
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容