sqlite c 语言

 

一.使用流程

要使用sqlite,需要从sqlite官网下载到三个文件,分别为sqlite3.lib,sqlite3.dll,sqlite3.h,然后再在自己的工程中配置好头文件和库文件,同时将dll文件放到当前目录下,就完成配置可以使用sqlite了。

使用的过程根据使用的函数大致分为如下几个过程:

//预编译方法:

// 创建数据库对象
sqlite3_open()
// 创建预编译对象       占位符只能是数据,不参是数据段名
sqlite3_prepare()

while(1)
{
    //绑定
    sqlite3_bind_int();  //绑定从1开始
    
    while(SQLITE_ROW == sqlite3_step())
    {
        char *p= sqlite3_column_text()
         输入p
    }
     sqlite3_reset();
}
//
sqlite3_finalize()
sqlite3_close()


 

SQLite的sqlite3_column_blob函数

SQLite3利用函数sqlite3_column_blob来返回blob字段的内容的指针,并通过sqlite3_column_bytes来返回对应该字段的长度。

只是一直有一个疑问就是通过sqlite3_column_blob返回的二进制blob内容的内存是谁来释放,是由SQLite内部还是用调用者来释放。

后来仔细观察了内存变化发现,

sqlite3_column_blob函数会预先分配一块内存,

每次调用sqlite3_step然后sqlite3_column_blob字段内容的时候,都会在这一个指定的空间内写入,

所以调用者不必去管理者块内存,也因此,每次sqlite3_column_blob返回的二进制内容都需重新写去到调用者需要的地方去,否则下次再有二进制读出的时候,原来的内容就会被释放掉。

sqlite3_bind_*系列函数有好多,这里只对sqlite3_bind_text进行一下说明,

sqlite3_bind_text的第二个参数为序号(从1开始),

第三个参数为字符串值,

第四个参数为字符串长度。

sqlite3_bind_text的第五个参数为一个函数指针,

SQLITE3执行完操作后回调此函数,通常用于释放字符串占用的内存。(这个函数指针参数具体怎么使用,我现在还不清楚)。此参数有两个常数,SQLITE_STATIC告诉sqlite3_bind_text函数字符串为常量,可以放心使用;

而SQLITE_TRANSIENT会使得sqlite3_bind_text函数对字符串做一份拷贝。

一般使用这两个常量参数来调用sqlite3_bind_text。

 

 

 

sqlite3_exec() 与sqlite3_step()区别:

sqlite3_exec() 就是把你提到的三个函数结合在了一起:sqlite3_step(), sqlite3_perpare(), sqlite3_finalize()。
然后提供一个回调函数进行结果的处理。

你可能感兴趣的:(数据库)