- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
嵌入式数据库介绍
打开数据库的流程 添加记录的流程 数据库的掉电保护策略 在进行记录操作和整理数据库时遇到掉电的情况,均会对数据库的完整性造成破坏。 写记录的过程在记录的数据首块中有掉电保护标志Flag 记录,如果不是0xC或0x0,则该记录不完整,需要修复。 删除记录的流程 修改记录的流程 查询记录 设置要查询记录为当前的排序表 按排序表折半查找 KDB的性能 在V6上测试 添加一条记录: 43MS 修改一条记录: 39MS 读取一条记录: 1.62MS 查找记录 :50.240 MS 删除一条记录: 20MS 打开数据库(包括整理): 156.40 MS * * * * * * * * * * * 在创建数据表时,指定primary key通常仅仅只是在相应于栏位创建一个单键索引,但是如果primary key是应用在一个数据类型为INTEGER的数据栏上,那么这个栏在内部被做为B树的索引键。如果数据表没有一个INTEGER PRIMARY KEY的栏位,那么B树将自动产生B树的键。也就是如果没有id这个键位的话,sqlite会有另一个列,其值表现为rowid。在SQLite中,每一个表中的表一行都一个一rowid,在一个表里面,rowid是唯一的,在sqlite2.8中,rowid是32bit,在3.0后,rowid用64bit来表示。可以用rowid, _rowid, oid来访问,如果你自己的表里面有一个rowid,那么,就使用你自己指定的rowid,而不是内的rowid.通常新插入的行rowid是最大的rowid+1,如果最大的rowid达到最大,那么,sqlite会随机取一个没有用的rowid。这也就是说,只要不删、不指定最大的rowid,那么rowid就是自动增加的,删除条目不会导致rowid的减小,所以如果表里面有100条数据,rowid等于100,全删后,rowid不会变化。AUTOINCREMENT关键字保证rowid的持续增长,如果达到最大值,则返回SQLITE_FULL的错误。last_insert_rowid() * SQLIte最强大之处之一莫过于用户自定义函数,自定义函数为增强sqlite的功能提供了强大的支持。自定的义函数和内置的函数(比如max, min)具有相同的地位。 * SQLite命令行功能使用 数据导入 sqlite.import data.txt employee sqlite提示:data.txt line1:expected 4 coloumns of data but found 1; 从经验应该能看出是字符分隔符有问题,先来看看系统用什么样的提示符: .show之后可以看到 separator: “|”,也就是说系统默认的分隔符为”|”面不是”,”,下面修改分隔字符: sqlite.separator “,” sqlite.import data.txt employee sqlite select * from employee where id 2; sqlite select * from employee where name 9999999999999; 上面这句用来说明textinteger(这个和比较字符的内码得到的结果是相同的) 数据比较 NULLINTERGER(REAL)TEXTBLOB 数字之间用数学比较方法比较 TEXT/BLOB用memcpy()进行比较 比较方法是可以自已定义或者重载的(我们将在后面提及中文字串的比较) Ex: sqlite select id 2, name ‘dong’, gender=‘male’ from employee; 0,1,1 0,1,0 1,1,1 1,0,1 1,1,1 SQLite命令行功能使用 下面举例说明SQLITE命令行的常规使用: SQLite数据导出 将数据表导出为数据创建脚本 sqlite .dump employee 上面的命令可以得到数据表相关的SQL语句,为了将输出保存的文件中,执行下面的命令。 sqlite .output create.sql sqlite .dump employee sqlite .output stdout (将输出恢复到标准输出) 将特定数据导出成数据文件 sqlite .output data_tmp.html sqlite select * from employee; sqlite .mode html employee sqlite select * from employee; sqlite .output stdout 上面的几条命令将employee中
您可能关注的文档
最近下载
- 电路电流练习.doc VIP
- 安全生产标准重大危险源管理人员培训记录.docx VIP
- 商业写字楼智能化初步设计在2025年的智能化物业管理系统评估报告.docx
- DB32_T 4342-2022工业企业全过程环境管理指南.docx VIP
- 传感器数字式传感器详解.ppt VIP
- 马工程外国文学史第一章古代文学.pptx VIP
- 低空经济行业市场前景及投资研究报告:Joby,Archer,国内eVTOL产业.pdf VIP
- 《数据可视化技术》课件.ppt VIP
- Unit 1 Helping at home 第5课时 Part B Let’s learn&Listen and chant(教学设计)英语人教PEP版四年级上册.pdf
- 《普通遗传学》第9章近亲繁殖和杂种优势.ppt
文档评论(0)