sqlite3函数使用说明2

前端之家收集整理的这篇文章主要介绍了sqlite3函数使用说明2前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。


sqlite操作二进制数据需要用一个辅助的数据类型:sqlite3_stmt *
这个数据类型记录了一个sql语句。为什么我把sql语句用双引号引起来?因为你可以把sqlite3_stmt *所表示的内容看成是sql语句,但是实际上它不是我们所熟知的sql语句。它是一个已经把sql语句解析了的、用sqlite自己标记记录的内部数据结构。
正因为这个结构已经被解析了,所以你可以往这个语句里插入二进制数据。当然,把二进制数据插到sqlite3_stmt结构里可不能直接memcpy,也不能像std::string那样用+号。必须用sqlite提供的函数来插入。
i.1
写入二进制
下面说写二进制的步骤。
要插入二进制,前提是这个表的字段的类型是blob类型。我假设有这么一张表:
create table Tbl_2( ID integer,file_content blob )
首先声明
sqlite3_stmt * stat;
然后,把一个sql语句解析到stat结构里去:
sqlite3_prepare( db,“insert into Tbl_2( ID,file_content) values( 10,? )”,-1,&stat,0 );
上面的函数完成sql语句的解析。第一个参数跟前面一样,是个sqlite3 *类型变量,第二个参数是一个sql语句。这个sql语句特别之处在于values里面有个?号。在sqlite3_prepare函数里,?号表示一个未定的值,它的值等下才插入。
第三个参数我写的是-1,这个参数含义是前面sql语句的长度。如果小于0sqlite自动计算它的长度(把sql语句当成以\0结尾的字符串)。
第四个参数是sqlite3_stmt的指针的指针。解析以后的sql语句就放在这个结构里。
第五个参数我也不知道是干什么的。为0就可以了。
如果这个函数执行成功(返回值是sqlITE_OKstat不为NULL),那么下面就可以开始插入二进制数据。
sqlite3_bind_blob( stat,1,pdata,(int)(length_of_data_in_bytes),NULL ); // pdata
为数据缓冲区,length_of_data_in_bytes为数据大小,以字节为单位
这个函数一共有5个参数。
1个参数:是前面prepare得到的sqlite3_stmt *类型变量。
2个参数:?号的索引。前面preparesql语句里有一个?号,假如有多个?号怎么插入?方法就是改变bind_blob函数2个参数。这个参数我写1,表示这里插入的值要替换stat的第一个?号(这里的索引从1开始计数,而非从0开始)。如果你有多个?号,就写多个bind_blob语句,并改变它们的第2个参数就替换到不同的?号。如果有?号没有替换,sqlite为它取值null
3个参数:二进制数据起始指针。
4个参数:二进制数据的长度,以字节为单位。
5个参数:是个析够回调函数,告诉sqlite当把数据处理完后调用函数来析够你的数据。这个参数我还没有使用过,因此理解也不深刻。但是一般都填NULL,需要释放的内存自己用代码来释放。
bind
完了之后,二进制数据就进入了你的sql语句里了。你现在可以把它保存到数据库里:
int result = sqlite3_step( stat );
通过这个语句,stat表示的sql语句就被写到了数据库里。
最后,要把sqlite3_stmt结构给释放:
sqlite3_finalize( stat ); //
把刚才分配的内容析构掉
i.2
读出二进制
下面说读二进制的步骤。
跟前面一样,先声明sqlite3_stmt *类型变量:
sqlite3_stmt * stat;
然后,把一个sql语句解析到stat结构里去:
sqlite3_prepare( db,“select * from Tbl_2”,0 );
prepare成功之后(返回值是sqlITE_OK),开始查询数据。
int result = sqlite3_step( stat );
这一句的返回值是sqlITE_ROW时表示成功(不是sqlITE_OK)。
你可以循环执行sqlite3_step函数,一次step查询出一条记录。直到返回值不为sqlITE_ROW时表示查询结束。
然后开始获取第一个字段:ID的值。ID是个整数,用下面这个语句获取它的值:
int id = sqlite3_column_int( stat,0 ); //
2个参数表示获取第几个字段内容,从0开始计算,因为我的表的ID字段是第一个字段,因此这里我填0
下面开始获取file_content的值,因为file_content是二进制,因此我需要得到它的指针,还有它的长度:
const void * pFileContent = sqlite3_column_blob( stat,1 );
int len = sqlite3_column_bytes( stat,1 );
这样就得到了二进制的值。
pFileContent内容保存出来之后,不要忘了释放sqlite3_stmt结构:
sqlite3_finalize( stat ); //
把刚才分配的内容析构掉
i.3
重复使用sqlite3_stmt结构
如果你需要重复使用sqlite3_prepare解析好的sqlite3_stmt结构,需要用函数sqlite3_reset
result = sqlite3_reset(stat);
这样,stat结构又成为sqlite3_prepare完成时的状态,你可以重新为它bind内容

4事务处理
sqlite
支持事务处理的。如果你知道你要同步删除很多数据,不仿把它们做成一个统一的事务。
通常一次sqlite3_exec就是一次事务,如果你要删除1万条数据,sqlite就做了1万次:开始新事务->删除一条数据->提交事务->开始新事务->…的过程。这个操作是很慢的。因为时间都花在了开始事务、提交事务上。
你可以把这些同类操作做成一个事务,这样如果操作错误,还能够回滚事务。
事务的操作没有特别的接口函数,它就是一个普通的sql语句而已:
分别如下:
int result;
result = sqlite3_exec( db,"begin transaction",&zErrorMsg ); //
开始一个事务
result = sqlite3_exec( db,"commit transaction",&zErrorMsg ); //
提交事务
result = sqlite3_exec( db,"rollback transaction",&zErrorMsg ); //
回滚事务

猜你在找的Sqlite相关文章