登录 注册
当前位置:主页 > 资源下载 > 34 > 操作二进制-线性代数及其应用中文版下载

操作二进制-线性代数及其应用中文版下载

  • 更新:2024-07-08 13:31:38
  • 大小:2.3MB
  • 推荐:★★★★★
  • 来源:网友上传分享
  • 类别:SQLite - 数据库
  • 格式:PDF

资源介绍

(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 语句的长度。如果小于 0,sqlite 会自动计算它的长度 (把 sql 语句当成以\0 结尾的字符串)。 第四个参数是 sqlite3_stmt 的指针的指针。解析以后的 sql 语句就放在这个结构里。 第五个参数我也不知道是干什么的。为 0 就可以了。 如果这个函数执行成功(返回值是 SQLITE_OK 且 stat 不为 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 个参数:?号的索引。前面 prepare 的 sql 语句里有一个?号,假如有多个?号怎么插入?方法就是改 变 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 读出二进制