位置: 编程技术 - 正文

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

编辑:rootadmin

推荐整理分享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)

  • 转登记纳税人按规定再次登记为一般纳税人后
  • 错账更正方法有哪几种
  • 月收入不足10万免增值税的账务处理
  • 弥补以前年度亏损从哪里取数
  • 发票种类和适用范围
  • 金融企业税务稽查案例分析
  • 商品卖亏的会计分录
  • 采购折扣怎么结转成本?
  • 建设单位收到施工承包单位的单位工程验收申请后应组织
  • 转账支票给员工转工资
  • 技术咨询合同包括就特定技术项目提供
  • 粮食仓储设施设备管理
  • 当月税负率怎么算
  • 赔偿款和罚款是一样的吗
  • 固定资产清理的借方
  • 长期借款的核算思维导图
  • 公司名下的车怎么上牌
  • 2016年最佳歌曲
  • i912900k用什么主板好
  • win10应用显示模糊发虚
  • window10总是自动开机
  • 上半年的业务总结几句话
  • 查账补缴的税的账怎么做
  • 关于工程材料的质量控制说法正确的是
  • 什么叫做材料成型工艺
  • win10电脑电源选项怎样设置最好
  • 建筑企业挂靠违法吗
  • 理财计算收益公式
  • PHP:pg_get_result()的用法_PostgreSQL函数
  • 小规模核定征收突然转查账
  • nullable object must have a value
  • 网络层IP协议的配套协议有哪些
  • 公牛牛角
  • 银行承兑汇票的付款人是谁?
  • thinkphp cli
  • 公司投资资金
  • 凭证字号怎么写
  • 发放工资时扣除的保险怎么做
  • vue如何配置路由
  • java单点登录token
  • sed指令可以打印文件的奇数或偶数行
  • taskset命令详解
  • 财政补助结转会计处理
  • 算税负是含税还是不含税
  • sql的应用
  • 代扣代缴个人所得税账务处理
  • 资源税的征税对象都是原矿和选矿
  • 付款方和发票抬头不一致会计处理
  • 对方多开票怎么处理
  • 当月作废的发票是否需要报税
  • 工资代发户怎么开
  • 把公司设备操作坏了怎么担责
  • 餐饮企业老板
  • 其他应付款贷方余额怎么冲平
  • 分公司费用报销
  • 企业微信对公账户认证
  • 发票金额小于实付金额会计分录
  • 长期待摊费用什么时候结束摊销
  • 销售额是营业额吗?
  • mysql 指定my.cnf
  • mssql CASE,GROUP BY用法
  • Windows Server 2008如何设置自动获取ip?设置自动获取ip教程
  • win7系统桌面图标不见了右键无反应
  • 一句命令
  • mac os x 10.12.2 Beta1怎么升级?macOS Sierra 10.12.2 Beta升级图文教程
  • win7怎么不显示桌面图标
  • 本地安全策略主要功能
  • linux安装的命令是啥
  • win7系统怎么查看内存
  • cocos2dx 3.0 beta android环境配置
  • cmd打开telnet
  • java list和array list区别
  • java list转set的方法
  • javascript要怎么学
  • 农业栽培技术
  • 公司代扣税怎么办理
  • 国税局征收的税种有哪些?
  • 上海市国家税务局
  • 厦门象屿正式员工招聘
  • 物化政的大学有哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设