位置: 编程技术 - 正文

SQLite教程(十四):C语言编程实例代码(2)

发布时间:2024-01-29

推荐整理分享SQLite教程(十四):C语言编程实例代码(2),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

三、高效的批量数据插入:

在给出操作步骤之前先简单说明一下批量插入的概念,以帮助大家阅读其后的示例代码。事实上,批量插入并不是什么新的概念,在其它关系型数据库的C接口API中都提供了一定的支持,只是接口的实现方式不同而已。纵观众多流行的数据库接口,如OCI(Oracle API)、MySQL API和PostgreSQL API等,OCI提供的编程接口最为方便,实现方式也最为高效。SQLite作为一种简单灵活的嵌入式数据库也同样提供了该功能,但是实现方式并不像其他数据库那样方便明显,它只是通过一种隐含的技巧来达到批量插入的目的,其逻辑如下:

1). 开始一个事物,以保证后面的数据操作语句均在该事物内完成。在SQLite中,如果没有手工开启一个事物,其所有的DML语句都是在自动提交模式下工作的,既每次操作后数据均被自动提交并写入磁盘文件。然而在非自动提交模式下,只有当其所在的事物被手工COMMIT之后才会将修改的数据写入到磁盘中,之前修改的数据都是仅仅驻留在内存中。显而易见,这样的批量写入方式在效率上势必会远远优于多迭代式的单次写入操作。

2). 基于变量绑定的方式准备待插入的数据,这样可以节省大量的sqlite3_prepare_v2函数调用次数,从而节省了多次将同一SQL语句编译成SQLite内部识别的字节码所用的时间。事实上,SQLite的官方文档中已经明确指出,在很多时候sqlite3_prepare_v2函数的执行时间要多于sqlite3_step函数的执行时间,因此建议使用者要尽量避免重复调用sqlite3_prepare_v2函数。在我们的实现中,如果想避免此类开销,只需将待插入的数据以变量的形式绑定到SQL语句中,这样该SQL语句仅需调用sqlite3_prepare_v2函数编译一次即可,其后的操作只是替换不同的变量数值。

SQLite教程(十四):C语言编程实例代码(2)

3). 在完成所有的数据插入后显式的提交事物。提交后,SQLite会将当前连接自动恢复为自动提交模式。 下面是示例代码的实现步骤:

1). 创建测试数据表。 2). 通过执行BEGIN TRANSACTION语句手工开启一个事物。 3). 准备插入语句及相关的绑定变量。 4). 迭代式插入数据。 5). 完成后通过执行COMMIT语句提交事物。 6). 删除测试表。 见以下代码及关键性注释:

该结果和上一个例子(普通数据插入)的结果完全相同,只是在执行效率上明显优于前者。

四、数据查询:

数据查询是每个关系型数据库都会提供的最基本功能,下面的代码示例将给出如何通过SQLite API获取数据。 1). 创建测试数据表。 2). 插入一条测试数据到该数据表以便于后面的查询。 3). 执行SELECT语句检索数据。 4). 删除测试表。 见以下示例代码和关键性注释:

SQLite教程(十三):C语言编程实例代码(1) 一、获取表的Schema信息:1).动态创建表。2).根据sqlite3提供的API,获取表字段的信息,如字段数量以及每个字段的类型。3).删除该表。见以下代码及关键

SQLite中重置自动编号列的方法 目前流行的数据库都提供了自动编号类型,SQLite也不例外。当数据库中包含自动编号的字段时,SQLite会自动建立一个名为sqlite_sequence的表。这个表包含

SQLite字符串比较时的大小写问题解决方法 大部分数据库在进行字符串比较的时候,对大小写是不敏感的。但是,最近使用SQLite的时候,却发现它的情况恰好相反。假设表User的结构和值如下:User

标签: SQLite教程(十四):C语言编程实例代码(2)

本文链接地址:https://www.jiuchutong.com/biancheng/312117.html 转载请保留说明!

上一篇:SQLite教程(十一):临时文件

下一篇:SQLite教程(十三):C语言编程实例代码(1)

  • 个人所得税人员信息采集验证不通过
  • 多缴纳了印花税有什么影响
  • 改革性补贴是否属于规范的津贴补贴
  • 什么是非关联方交易
  • 母公司对子公司的债务承担连带责任
  • 多开的增值税发票交多少税
  • 办公室租赁费计入什么科目
  • 公户转到老板私人账户
  • 收购股权怎么做账
  • 企业所得税根据什么报表申报
  • 扣个税必须要交社保吗
  • 社保可以在税前扣除吗
  • 注册资本没有缴足前贷款利息
  • 什么是应交税费应交增值税科目设置的贷方明细科目
  • 为什么增值税普通发票不能抵扣
  • 土地增值税清算是什么意思
  • 行政事业性收费计入什么科目
  • 个人出租商业用房取得的所得
  • 小微企业应纳税所得额不超过100万
  • 核定征收的企业利润怎么处理
  • 普通支票如何转账
  • 生产车间购入材料会计分录
  • 预提费用支付是指什么
  • 简易计税分包抵减
  • PHP:oci_result()的用法_Oracle函数
  • 吉隆坡石油双塔有多高
  • 如何设置两台路由器连接
  • 以前年度多计提的附加税怎么冲回
  • 跨年冲减无发票怎么入账
  • php fwrite函数
  • 业绩补偿是什么意思
  • vue实现打印
  • 已开票未收款怎么做账
  • 冲回暂估分录
  • 融资租赁印花税怎么缴纳
  • 后端怎么把图片传给前端的
  • 企业安全生产费用不得出现赤字
  • php计算时间
  • php抽象类可以多继承吗
  • 可供出售权益工具减值
  • 非成品油发票为什么不能抵扣
  • 非货币性资产交换和债务重组的区别
  • 一个简单的web项目名称
  • 帝国cms使用手册
  • mongodb的redo日志为
  • 用于职工福利的固定资产折旧
  • 什么情况下要缴纳房产税
  • 承租人损坏租赁物
  • 幼儿园的经费支出主要包括哪几个方面
  • 期末余额就是本年累计吗
  • 企业选择的短期调整
  • 进口货物的完税价格计算公式
  • 什么是存货周转期间
  • 在职职工暖气费补助款
  • 营改增后租金收入交什么税
  • 税盘进项税额怎么做
  • 工程预付款入账
  • 现金日记账怎么记账
  • 汽车以租代售合法吗
  • 应收账款管理应该收集哪些信息
  • 融资租入固定资产的账务处理
  • 美元利息结汇时结汇项目是什么
  • 会展费会计分录
  • 内部审计人员独立性
  • mysql新手视频教学
  • java调用so库文件
  • 系统自动设置网络连接
  • 虚拟网卡在哪里设置
  • win10家庭版免费升级专业版密钥
  • font:inherit
  • JavaScript Math.ceil() 函数使用介绍
  • pycharm官方教程
  • js动态执行代码
  • js拖拽生成页面
  • python实现识别相似图片小结
  • 如何使用wordpress
  • 怎么检查手机网络
  • 外贸公司委托加工的账务怎么处理
  • 12333热线时间
  • 法治税务演讲稿结尾
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号