`
chinamming
  • 浏览: 151375 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

SQlite数据库的C编程接口(五) 便捷函数(Convenience Functions) ——《Using SQlite》读书笔记

 
阅读更多

SQlite数据库的C编程接口(五) 便捷函数(Convenience Functions) by斜风细雨QQ:253786989 2012-02-07

SQlite拥有很多早期遗留下来的便捷函数,这些函数存在很多缺点。当然他们依然存在就有理由——使用方便。

它们的优点也仅仅是使用方便,而不是具有很好的性能。相反,它们的性能会比直接调用PUBLICAPI函数更差一些。对于这些便捷函数,它们并没有什么特别之处,只是在这些函数内部调用sqlite3_prepare_xxx、sqlite3_step、sqlite3_finalizeAPI函数来完成一站式功能。在这样的函数内部往往存在很多额外的类型转换,所以这些函数很可能会比我们自己去调用sqlite3_prepare_xxx、sqlite3_step、sqlite3_finalizeAPI执行的更慢一些。

其次,这些API不支持参数绑定。就像上一篇笔记中介绍的,这样的程序更容易遭到“SQL注入攻击”,安全性更差。

总之,作者JayA.Kreibich非常不推荐使用这些便捷函数。正如他说的:“Ifyou’rejusttryingtothrowtogetheraquickanddirtysnippetofcode,thesefunctionsprovideaneasymeansofdoingthat.Istronglyrecommendusingthenormalprepare,step,andfinalizeroutines.You’llendupwithsafercodeandbetterperformance.

(1)

  1. intsqlite3_exec(
  2. sqlite3*,/*Anopendatabase*/
  3. constchar*sql,/*SQLtobeevaluated*/
  4. int(*callback)(void*,int,char**,char**),/*Callbackfunction*/
  5. void*,/*1stargumenttocallback*/
  6. char**errmsg/*Errormsgwrittenhere*/
  7. );

预处理(prepare)和执行(execute)一条或多条SQL语句,对结果集的每一行调用其第3个参数所指向的回调函数。第1个参数指向一个有效的数据库连接。第2个参数是UTF-8编码的SQL语句(可以包含一条,或多条:以分号隔开)。第3个参数是一个指向回调函数的指针,如果不需要使用回调函数,可以给该参数传递NULL。第4个参数也是一个指针,用来传递用户数据到回调函数。需要注意的是,比如该指针由sqlite3_malloc获得,则要在其不再使用时调用sqlite3_free函数释放。第5个参数是一个指向指针的指针,通过该参数返回错误码。如果在sqlite3_exec执行过程中,没有遇到任何错误,最后函数将返回SQLITE_OK

比如sqlite3_exec正在执行SELECT查询操作,而且想对返回结果进行处理。那就要传递一个回调函数给sqlite3_exec。这样sqlite3_exec函数每次获取一行数据,就会调用该回调函数。如果sqlite3_exec正在执行的操作不返回数据,就直接给sqlite3_exec函数的第3个参数传递NULL就可以了。

回调函数原型:

  1. intuser_defined_exec_callback(void*userData,intnumCol,char**colData,char**colName)

第1个参数对应于sqlite3_exec函数的第4个参数,用于传递用户数据。第2个参数指明结果集中一共有多少列。第3个参数保存当前数据行的数据,第4个参数保存当前数据行的所有列的列名。第3个参数和第4个参数都是以字符串的形式返回。

正常情况下,回调函数应该返回0,如果它返回一个非0值,则sqlite3_exec函数将终止执行,并返回SQLITE_ABORT错误码。

(2)

  1. intsqlite3_get_table(
  2. sqlite3*db,/*Anopendatabase*/
  3. constchar*zSql,/*SQLtobeevaluated*/
  4. char***pazResult,/*Resultsofthequery*/
  5. int*pnRow,/*Numberofresultrowswrittenhere*/
  6. int*pnColumn,/*Numberofresultcolumnswrittenhere*/
  7. char**pzErrmsg/*Errormsgwrittenhere*/
  8. );

这个函数与sqlite3_exec函数不同,它只在SQL命令字符串执行完成之后,返回全部的结果数据。该函数是专门针对SELECT语句设计的。

第1个参数是指向数据库连接的指针。第2个参数是UTF-8编码的SQL命令字符串。第3个参数看起来有点复杂,通过该参数返回SQL语句执行结果。首先该参数是一个指针,它指向一个一维数组,这个一维数组里面保存的元素类型是字符串指针。第4个和第5个参数返回结果集中的行数和列数。最后一个参数返回错误码。

函数执行完成返回的结果集中,包含(nColumn*(nRow+1))个数据项。其中多出来的一行是列名,剩下的nColumn*nRom项是数据。

如果sqlite3_get_table函数执行过程中没遇到任何错误,最后会返回SQLITE_OK

下面是对结果集的一个访问例子,获取结果集中第R行,第C列的数据:

  1. /*offsettoaccesscolumnCofrowRof**result*/
  2. intoffset=((R+1)*numCol)+C;
  3. char*value=result[offset];

传递给sqlite3_get_table函数的SQL命令字符串可以包含多条SELECT语句。但是,对于这多条SELECT语句的返回结果全部存储在pazResult所指向的一维数组中。没有办法确定一维数组中,哪些行数据是哪个SELECT语句检索出来的。并且所有的SELECT语句所返回的列数必须相同,否则sqlite3_get_table函数执行失败。除此之外,只有第一条语句会返回列名,存储在结果集一维数组的第一行中。基于以上原因,最好在每次调用sqlite3_get_table函数时使用单独一条SQL命令。

(3)

  1. voidsqlite3_free_table(char**result);

sqlite3_get_table函数返回的结果集,所占用的内存,需要由sqlite3_free_table函数来释放。

SQlite数据库的C编程接口(五) 便捷函数(Convenience Functions) by斜风细雨QQ:253786989 2012-02-07

分享到:
评论

相关推荐

    SQLite数据库C语言编程的demo示例

    内容概要:这是一个通过显式调用(dlopen)方式,使用SQLite库API函数C语言编程的demo示例。里面包含了SQLite数据库文件的创建、数据库表创建、插入、修改、删除、查询等功能操作。该资源包中的程序有在Ubuntu环境下...

    基于Qt4的SQLite数据库应用编程

    标题“基于Qt4的SQLite数据库应用编程”揭示了文档将要介绍的知识点,即如何在Qt4框架下进行SQLite数据库的应用编程。从描述中我们知道,Qt是一个由挪威TrollTech公司开发的C++图形用户界面应用程序框架,支持跨平台...

    基于Qt4的SQLite数据库应用编程.pdf

    ### 基于Qt4的SQLite数据库应用编程 #### 概述 《基于Qt4的SQLite数据库应用编程》是一篇详细介绍如何在Qt4框架下利用SQLite数据库进行应用程序开发的技术文章。作者潘学文和文汉云来自长江大学计算机科学学院,...

    使用C#开发的Sqlite数据库创建、操作的源码项目工程

    这是一个使用C#开发的Sqlite数据库创建、操作的源码工程,关于Sqlite的所有操作已经单独创建了专门的跨平台【.NETCore3.1】类库包含相应的帮助类,可以直接生成后拿到任何项目中直接使用,高效简单,省去了从头开发...

    Android实验报告Sqlite数据库操作.pdf

    Android SQLite 数据库操作报告 一、实验目的 Android 实验报告的主要目的是熟悉 Android 平台的文件操作、掌握 Android SQLite 数据库的设计和应用、熟悉 XML 和 JSON 文件的读取。通过本实验,用户可以掌握 ...

    SQLite数据库逆向分析1

    SQLite数据库逆向分析 ...在SQLite数据库逆向分析中,我们需要寻找SQLite数据库中回调函数的样板,以便于了解数据库的实现机理和数据结构。通过分析函数的调用过程,我们可以了解数据库的数据结构和实现机理。

    Delphi版SQLite数据库工具

    Delphi版SQLite数据库工具是一款专为开发者设计的实用软件,主要用于在Delphi编程环境中与SQLite数据库进行交互。SQLite是一款轻量级、自包含的数据库引擎,广泛应用于嵌入式系统和移动应用,因其高效性和无需服务器...

    VB6.0 操作SQLite 数据库的完整示例代码

    在VB6.0中操作SQLite数据库,是一种将轻量级、高性能的SQLite数据库与传统的Visual Basic编程环境相结合的方法。SQLite是一种自包含、无服务器、零配置、事务性的SQL数据库引擎,广泛应用于移动设备、嵌入式系统以及...

    SQLite数据库 加密解密工具

    SQLite数据库是一种轻量级、自包含的SQL数据库引擎,常被用在嵌入式系统和移动应用中。在处理敏感数据时,为了保护信息安全,对SQLite数据库进行加密是必要的步骤。本文将详细介绍如何使用.NET环境下的SQLite加密...

    sqlite3 C语言接口

    SQLite3 C 语言接口是 SQLite3 数据库管理系统提供的一种编程接口,允许 C 语言程序员使用 SQLite3 数据库。该接口提供了一系列函数和数据结构,用于创建、操作和管理 SQLite3 数据库。 快速入门 SQLite3 C 语言...

    js 访问 sqlite数据库

    1. **Web SQL Database**(不推荐):这是W3C曾经提出的一个标准,允许在Web应用中使用SQLite数据库。开发者可以通过SQL语法直接操作数据库。但请注意,这个标准已被废弃,不再推荐使用。 2. **IndexedDB**:这是一...

    SQLiteCompareSetup(SQLite数据库比较工具)

    SQlite数据库工具 供比较两个SQLite数据库所用。

    SQLite数据库打开工具

    SQLite是一款轻量级的、开源的、自包含的SQL数据库引擎,它不需要单独的服务器进程,可以直接嵌入到各类应用程序中。SQLite具有高度移植性,支持多种操作系统和编程语言,如Windows、Linux、Mac OS、Java、C++、...

    Android源码——数据库SQLite.zip

    这个压缩包文件"Android源码——数据库SQLite.zip"可能包含了关于Android中SQLite数据库的源码分析、使用示例以及相关的图像资源,如1-120912223R80-L.png,可能用于解释或展示SQLite在Android中的工作原理。...

    Linux下嵌入式系统中SQlite数据库的应用.pdf

    其中,接口由核心API和扩展API组成,核心API实现基本的数据库操作,扩展API通过创建自定义的SQL函数去扩展SQLite。编译器中,分词器和分析器对SQL语句进行语法检查,最后生成针对SQLite的汇编代码。虚拟机是架构中最...

    全国省市区sqlite数据库

    此外,因为SQLite支持多种编程语言的接口,如Python、Java、C#等,所以可以方便地将这个数据库集成到各种软件项目中。 为了进一步处理和分析这些数据,你可能需要了解如何使用SQLite命令行工具,或者在编程环境中...

    C++操作sqlite数据库

    C++操作sqlite数据库简明教程及示例代码 C++操作sqlite数据库是指使用C++语言来操作sqlite数据库的过程。sqlite数据库是轻量级的关系数据库管理系统,广泛应用于移动设备、嵌入式系统和桌面应用程序中。使用C++语言...

    Qt中 SQlite 数据库 加密 SqliteCipher 实例

    Qt中SQlite数据库加密SqliteCipher 操作实例,打开多个数据库,附着数据库跨库查询, 对应说明:https://blog.csdn.net/woguanni/article/details/120524602

    Android 绿豆通讯录【SQLite数据库】

    前情提要:Android 数据库(SQLite) 【简介、创建、使用(增删改查、事务、实战演练)、数据显示控件(ListView、Adapter、实战演练)】 https://blog.csdn.net/weixin_44949135/article/details/105955663  Android ...

    Android中SQLite数据库查看工具

    SQLite是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。它是一个零配置的数据库,这意味着与其他数据库不一样,您不需要在系统中配置。 就像其他数据库,SQLite 引擎不是一个...

Global site tag (gtag.js) - Google Analytics