十三章Basic Data Persistence-----之三(数据库存储)

以前写过slq语句,有一些基础,但很久不用,还要加强一下。先把一些有疑问的句型熟悉一下:

sqlite3_stmt *stmt;

这个数据类型记录了一个“sql语句”。为什么我把 “sql语句” 用双引号引起来?因为你可以把 sqlite3_stmt * 所表示的内容看成是 sql语句,但是实际上它不是我们所熟知的sql语句。它是一个已经把sql语句解析了的、用sqlite自己标记记录的内部数据结构。

正因为这个结构已经被解析了,所以你可以往这个语句里插入二进制数据。当然,把二进制数据插到 sqlite3_stmt 结构里可不能直接 memcpy ,也不能像 std::string 那样用 + 号。必须用 sqlite 提供的函数来插入。

char *update = "INSERT OR REPLACE INTO FIELDS (ROW, FIELD_DATA) " "VALUES (?, ?);";

这个 sql 语句特别之处在于 values 里面有个 ? 号。在sqlite3_prepare函数里,?号表示一个未定的值,它的值等下才插入。

sqlite3_prepare_v2(database, update, -1, &stmt, nil)

第一个参数打开的slqite3数据库指针,是个 sqlite3 * 类型变量,

第二个参数是一个 sql 语句,就是前面的插入语句

第三个参数我写的是-1,这个参数含义是前面 sql 语句的长度。如果小于0,sqlite会自动计算它的长度(把sql语句当成以\0结尾的字符串)。

第四个参数是 sqlite3_stmt 的指针的指针。就是前面定义的,解析以后的sql语句就放在这个结构里。

第五个参数我也不知道是干什么的。为0就可以了。

如果这个函数执行成功(返回值是 SQLITE_OK 且 stat 不为NULL ),那么下面就可以开始插入二进制数据。

sqlite3_bind_int(stmt, 1, i);

这个只有三个参数,和后面的解释一样。
sqlite3_bind_text(stmt, 2, [field.text UTF8String], -1, NULL);

这个函数一共有5个参数。

第1个参数:是前面prepare得到的 sqlite3_stmt * 类型变量。

第2个参数:?号的索引。前面prepare的sql语句里有一个?号,假如有多个?号怎么插入?方法就是改变此 函数第2个参数。这个参数我写1,表示这里插入的值要替换stmt的第一个?号(这里的索引从1开始计数,而非从0开始)。如果你有多个?号,就写多个 bind语句,并改变它们的第2个参数就替换到不同的?号。如果有?号没有替换,sqlite为它取值null。

第3个参数:二进制数据起始指针。

第4个参数:二进制数据的长度,以字节为单位。

第5个参数:是个析够回调函数,告诉sqlite当把数据处理完后调用此函数来析够你的数据。这个参数我还没有使用过,因此理解也不深刻。但是一般都填NULL,需要释放的内存自己用代码来释放。

int result = sqlite3_step( stmt);

通过这个语句,stat 表示的sql语句就被写到了数据库里。

最后,要把 sqlite3_stmt 结构给释放:

sqlite3_finalize( stmt); //把刚才分配的内容析构掉


ok了,有了前面的解释数据库这块应该没有什么问题了。就不再写实现代码了,和书上的一样,下面就看看core data是个什么东东。




你可能感兴趣的:(十三章Basic Data Persistence-----之三(数据库存储))