大佬教程收集整理的这篇文章主要介绍了SQLite学习手册,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
很有用的开源跨平台数据库,可以作为客户端的小型内存数据库使用,据说它有N多用户(@H_502_7@@H_502_7@Nokia's Symbian,Mozilla,Abobe,Google,阿里旺旺,飞信,Chrome,firefox@H_502_7@),记录下。@H_502_7@@H_502_7@
下文转自:
@H_502_7@ http://www.cnblogs.com/stephen-liu74/archive/2012/03/09/2328757.html
@H_502_7@
sqlite学习手册(开篇)@H_502_7@@H_502_7@
Nokia's Symbian,Mozilla,Abobe,Google,阿里旺旺,飞信,Chrome,firefox 网上关于sqlite的介绍一抓一大把,总结起来,他有如下特点: 轻量级 不适合并发性高的场合 如大量insert,update访问,sql标准支持不全 sqlite官方网站没有与Access对比的说明,我觉得应该是:sqlite是开源的,单文件,不仅可以运行在windows上,也可以运行在各种linux系统上,而他的很多场合跟Access是不同的,他的优势足以站在一个比Access更高的位置,所以没有可比性,但我们普通人拿Access跟sqlite比,是因为他们交集的地方,关系到我们取舍。 交集处有:windows系统里web/winform, 在我的测试中 同样的数据,同样的SQL语句: ASP.net使用Microsoft Web Application Stress Tool进行1000个线程的压力测试1分钟,使用Elmah.dll记录错误,测试后没发现程序报错,也只是很占cpu而已 通过本人测试,sqlite也应该算是比较适合高并发,及多线程,但官方说不适合,不知道是不是我测试方法不对 sqlite的官方主页: sqlite中文站: System.Data.sqlite: sql学习笔记之 嵌入式数据库(sqlite,firebird) sqlite Expert(可选数据库编码,支持原生配置各种参数,软件更新@R_618_10322@,一天一个或多个版本,经试用,发现还有很多不完善的地方): Navicat for sqlite(导入,导出功能强大,功能实用,操作直观,有些小缺陷,更新速度还行): sqlite administrator(古老,但还是有很多人觉得不错,编码支持不强,可能乱码): firefox管理sqlite的插件 sqlite Manager(没多使用。看起来不错): 开源有感系列 之开源数据库有感[新内容添加版本]: 到底sqlite有多强?在我的2台机器上的压力测试: Access和Firebird及sqlite的性能比较 浅谈sqlite——实现与应用: sqlite数据库是中小站点CMS的最佳选择: sqlite的局限性: sqlite常见问题: MysqL大战sqlite(POSTGResql强势乱入): sqlite是一个轻量级、跨平台的关系型数据库。既然号称关系型数据库,支持sql92标准中常用的玩意儿(比如视图、事务、触发器等)就是理所当然的了,咱今天就不细说了。今天主要聊聊一些有点特色的玩意儿。 ◇轻量级 ◇绿色软件 ◇单一文件 ◇跨平台/可移植性 ◇内存数据库(in-memory database) 前面光聊了特性和优点,为了避免枪手写软文的嫌疑,再来说说sqlite的一些缺点。列位看官将来如果想用它,这些缺点要权衡一下。 ◇并发访问的锁机制 ◇sql标准支持不全 ◇网络文件系统(以下简称NFS) sqlite支持很多种语言的编程接口。这对于我这种喜欢混用多种编程语言的人来说,是很爽的。下面我大概介绍一下。 ◇C/C++ 前面讲的都是技术层面的话题,如果你考虑在公司的商业软件项目中使用SQLite。还需要根据“如何选择开源项目”里面提到的几个参考因素,再评估一下。
http://www.cnblogs.com/stephen-liu74/archive/2012/01/09/2317603.html
一、简介@H_502_7@
二、sqlite的主要优点@H_502_7@
三、和RDBMS相比sqlite的一些劣势@H_502_7@
四、个性化特征@H_502_7@
sqlite学习手册(C/C++接口简介)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/13/2321386.html
一、概述@H_502_7@
二、核心对象和接口@H_502_7@
三、参数绑定@H_502_7@
sqlite学习手册(数据表和视图)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/13/2321668.html
一、创建数据表@H_502_7@
二、表的修改@H_502_7@
三、表的删除@H_502_7@
四、创建视图@H_502_7@
五、删除视图@H_502_7@
sqlite学习手册(内置函数)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/13/2322027.html
一、聚合函数@H_502_7@
二、核心函数@H_502_7@
三、日期和时间函数@H_502_7@
sqlite学习手册(索引和数据分析/清理)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/14/2322335.html
一、创建索引@H_502_7@
二、删除索引@H_502_7@
三、重建索引@H_502_7@
四、数据分析@H_502_7@
五、数据清理@H_502_7@
sqlite学习手册(数据库和事物)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/14/2322575.html
一、Attach数据库@H_502_7@
二、Detach数据库@H_502_7@
三、事物@H_502_7@
sqlite学习手册(表达式)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/16/2323907.html
一、常用表达式@H_502_7@
二、条件表达式@H_502_7@
三、转换表达式@H_502_7@
sqlite学习手册(数据类型)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/18/2325258.html
一、存储种类和数据类型@H_502_7@
二、类型亲缘性@H_502_7@
三、比较表达式@H_502_7@
四、操作符@H_502_7@
sqlite学习手册(命令行工具)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/18/2325981.html
sqlite学习手册(在线备份)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/19/2326309.html
一、常用备份@H_502_7@
二、在线备份APIs简介@H_502_7@
三、高级应用技巧@H_502_7@
sqlite学习手册(内存数据库)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/20/2328348.html
一、内存数据库@H_502_7@
二、临时数据库@H_502_7@
sqlite学习手册(临时文件)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/21/2328483.html
一、简介@H_502_7@
二、具体说明@H_502_7@
三、相关的编译时参数和指令@H_502_7@
四、其它优化策略@H_502_7@
sqlite学习手册(锁和并发控制)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/01/22/2328753.html
一、概述@H_502_7@
二、文件锁@H_502_7@
三、回滚日志@H_502_7@
四、数据写入@H_502_7@
五、sql级别的事物控制
sqlite学习手册(实例代码<一>)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/02/07/2340780.html
一、获取表的scheR_67_11845@a信息
二、常规数据插入
sqlite学习手册(实例代码<二>)@H_502_7@@H_502_7@
http://www.cnblogs.com/stephen-liu74/archive/2012/02/07/2341480.html
三、高效的批量数据插入
四、数据查询
@H_502_7@哪些人,哪些公司或软件在用sqlite:
可见sqlite的稳定性及性能是不会有什么问题的,详细列表请参见:http://www.sqlite.org/famous.html。sqlite优点及适应场合:
绿色组件
单一文件
跨平台
查询效率极高
使用事务插入@R_618_10322@
支持limit分页
适合查询速度要求较高,内存占用较少的场合,尤其是嵌入式操作系统,如各种手机操作系统,低并发web(99.9%网站是低并发),php环境里原生支持sqlite,asp.net/.net winform里可以很方便的使用System.Data.sqlite缺点与不适应场合:
sqlite vs Access
一次插入5行及以上,每行有20来个字符,sqlite使用事务速度远快于access
一次插入多行,每行有8000以上字符,sqlite使用事务速度 快于 access 一倍左右
sqlite查询@R_618_10322@,甚至快过sql Server 2008 r2 10倍(因为MSsql索引列不能超过900个字符,所以varchar(maX)不能建索引)
单条数据插入速度比Access略慢,事务插入大量数据,在每行数据量不大时,远快于Access
Access经常出现数据库坏的情况,sqlite听说没有这个问题。
sqlite极速SELEct测试
SELECT * FROM dbo.Articles WHERE txtContent liKE '%柳永法%'
在sqlite及MSsql上执行效率让人震撼,sqlite竟然快MSsql 10倍,
并且sqlite没有进程只看到程序进程内存没有任何升高,而MSsql的进程则从1G多升到了3G多
数据库
条数
查询用时
sqlite
118848
60s
MSsql
540s
7428
6s
60s
关于sqlite多线程及ASP.net并发测试
sqlite资源地址:
http://www.sqlite.org/
http://www.sqlite.com.cn/
http://sqlite.phxsoftware.com/
http://www.cnblogs.com/ljzforever/archive/2010/03/09/1681453.htmlsqlite GUI图形管理工具:
http://www.sqliteexpert.com/download.html
http://www.navicat.com/en/download/download.html
http://sqliteadmin.orbmu2k.de/
https://addons.mozilla.org/en-US/firefox/addon/5817/sqlite参考资料:
http://www.cnblogs.com/unruledboy/archive/2005/02/04/98604.html
http://www.cnblogs.com/unruledboy/archive/2005/03/26/sqliteperfoRMANce.html
http://www.cnblogs.com/kevin-moon/archive/2008/12/01/1344658.html
http://www.cnblogs.com/Kevin-moon/archive/2008/11/14/1333285.html
http://www.cnblogs.com/hustcat/archive/2010/01/27/1657821.html
http://www.dbanotes.net/database/@R_527_5607@cms.html
http://dev.firnow.com/course/7_databases/sql/sqlServer/200838/103309.html
http://dev.firnow.com/course/7_databases/sql/sqlServer/200838/103310.html
http://obmem.com/?p=493
★sqlite技术上的优点和特性
先说它的第一个特色:轻量级。想必sqlite的作者很看重这个特性,连它的logo都是用的“羽毛”,来显摆它的轻飘飘。
sqlite和C/S模式的数据库软件不同,它是进程内的数据库引擎,因此不存在数据库的客户端和服务器。使用SQLite一般只需要带上它的一个动态库,就可以享受它的全部功能。而且那个动态库的尺寸也挺小,3.6.27版本也就几百K
sqlite的另外一个特点是绿色:它的核心引擎本身不依赖第三方的软件,使用它也不需要“安装环境”(如:oledb等)。所以在部署的时候能够省去不少麻烦。
所谓的“单一文件”,就是数据库中所有的信息(比如表、视图、触发器、等)都包含在一个文件内。这个文件可以copy到其它目录或其它机器上,也照用不误。
如果光支持主流操作系统(windows,linux),那就没啥好吹嘘的了。除了主流操作系统,sqlite还支持了很多小型嵌入式系统,比如AndroID、windows Mobile、Symbin、Palm、VxWorks等,也就是说iPhone,AndroID等手机上都可以用。
这年头,内存越来越便宜,很多普通PC都开始以GB为单位来衡量内存(服务器就更甭提了)。这时候,sqlite的内存数据库特性就越发显得好用。
sqlite的API不区分当前操作的数据库是在内存还是在文件(对于存储介质是透明的)。所以如果你觉得磁盘I/O有可能成为瓶颈的话,可以考虑切换为内存方式。切换的时候,操作sqlite的代码基本不用大改,只要在开始时把文件Load到内存,结束时把内存的数据库Dump回文件就OK了。在这种情况下,前面提到的“online BACkup API”就派上用场了,聪明的同学应该明白我为啥这么期待BACkup功能了吧?★技术上的缺点和不足
sqlite在并发(包括多进程和多线程)读写方面的性能一直不太理想。数据库可能会被写操作独占,从而导致其它读写操作阻塞或出错。
在它的官方网站上,具体列举了不支持哪些sql92标准。我个人感觉比较不爽的是不支持外键约束。
有时候需要访问其它机器上的sqlite数据库文件,就会把数据库文件放置到网络共享目录上。这时候你就要小心了。当sqlite文件放置于NFS时,在并发读写的情况下可能会出问题(比如数据损坏)。原因据说是由于某些NFS的文件锁实现上有BUG。★编程语言接口
由于sqlite本身是C写的,它自带的API也是C接口的。所以C/C++用起来最直接了。假如你不喜欢面向过程的C API风格,可以另外找个C++的包装库。想重新发明轮子的同学,也可以自己包装一个。
◇Java
如果要用Java访问sqlite,可以通过sqlite的JDBC驱动,或者通过专门的sqlite包装库。我个人建议走JDBC方式,万一将来要换数据库,代码就不用大改。
◇Python
pysqlite是Python操作sqlite的首选。从Python 2.5开始,它已经被整合到Python的标准库中。看来Python社区还是蛮喜欢sqlite嘛。
◇.net
对于喜欢.net的同学,可以通过System.Data.sqlite来访问。
◇Ruby
Ruby可以通过sqlite-Ruby操作sqlite数据库,不过我没用过。
◇Perl
在CPAN上有DBD::sqlite,不过我也没用过。★一些非技术的参考因素
◇授权协议(license)
sqlite使用的是public domain协议,这是最爽一种,可以放心大胆地用。
◇用户的普及程度
最近这几年,使用SQLite的人越来越多(从Google Trends可以反应出来)。包括一些大公司也开始把它整合到产品中(比如Google的Gears、Apple的Safari、Adobe的AIR)。这说明它的健壮性、稳定性等方面不会有太大问题。
◇开发的活跃程度 如果到sqlite的Change Log上大致了解一下,可以看出最近5年基本上每1-2个月都会有更新。说明开发的活跃度还是非常高的。 从上述几个非技术因素来看,sqlite用于商业公司的软件项目还是非常靠谱的。
以上是大佬教程为你收集整理的SQLite学习手册全部内容,希望文章能够帮你解决SQLite学习手册所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。