sqlite 资料整理(一)

怎人,哪些企业或者软件在用SQLite:

Nokia’s Symbian,Mozilla,Abobe,Google,阿里旺旺,飞信,Chrome,FireFox
可见SQLite的安定团结与性是匪见面出什么问题的,详细列表请参见:http://www.sqlite.org/famous.html。

网上关于SQLite的牵线一抓一不胜把,总结起来,他来如下特征:

SQLite优点及适应场地:

轻量级 绿色组件 单一文本 跨平台 查询效率极高 使用工作插入速度极快
支持limit分页
适合查询速度要求于高,内存占用比较少的场地,尤其是嵌入式操作系统,如各种手机操作系统,低并发web(99.9%网站是低产出),php环境里原生支持SQLite,asp.net/.net
winform里可以非常有利的运用System.Data.SQLite

缺陷和非适应场地:

无合乎并发性高的场所 如大量insert,update访问,SQL标准支持非都

SQLite vs Access

SQLite官方网站没有与Access对比的证实,我以为当是:SQLite是开源的,单文件,不仅可以运行于Windows上,也得以运作在各种Linux系统上,而异的大队人马场合跟Access是例外之,他的优势足站在一个比Access更强之位置,所以无可比性,但我们老百姓拿Access跟SQLite比,是坐她俩混合的地方,关系及我们选。

错落处有:windows系统里web/winform,

于自我之测试着
一不成栽5行及以上,每行有20来只字符,SQLite使用工作速度远快被access
一差栽多实践,每行有8000之上字符,SQLite使用工作速度 快于 access
一倍增左右 SQLite查询速度极快,甚至快过SQL Server 2008 r2
10加倍(因为MSSQL索引列不可知过900单字符,所以varchar(max)不克建索引)
单漫长数据插入速度比Access略慢,事务插入大量数,在每行数据量不大时,远快于Access
Access经常出现数据库坏之状,SQLite听说没有这题材。

SQLite资源地址:

SQLite的官方主页: http://www.sqlite.org/

SQLite中文站: http://www.sqlite.com.cn/

System.Data.SQLite: http://sqlite.phxsoftware.com/

sql学习笔记之 嵌入式数据库(sqlite,firebird)
http://www.cnblogs.com/ljzforever/archive/2010/03/09/1681453.html

SQLite GUI图形管理工具:

SQLite
Expert(可选数据库编码,支持原生配置各种参数,软件更新快极其快,一天一个要多个版本,经试用,发现尚来多不全面的地方):
http://www.sqliteexpert.com/download.html

Navicat for
SQLite(导入,导出功能强大,功能实用,操作直观,有几稍瑕疵,更新速度还行):
http://www.navicat.com/en/download/download.html

SQLite
Administrator(古老,但要么发生成千上万总人口觉着不错,编码支持不赛,可能乱码):
http://sqliteadmin.orbmu2k.de/

FireFox管理SQLite的插件 SQLite Manager(没多采用。看起对):
https://addons.mozilla.org/en-US/firefox/addon/5817/

 

SQLite参考资料:

开源有谢系列 之起源数据库有谢[初情节丰富本]:
http://www.cnblogs.com/unruledboy/archive/2005/02/04/98604.html

究竟SQLite有多高?在自我之2华机械上的下压力测试:
http://www.cnblogs.com/unruledboy/archive/2005/03/26/sqliteperformance.html

Access和Firebird及SQLite的性质比
http://www.cnblogs.com/kevin-moon/archive/2008/12/01/1344658.html
http://www.cnblogs.com/Kevin-moon/archive/2008/11/14/1333285.html

浅谈SQLite——实现同下:
http://www.cnblogs.com/hustcat/archive/2010/01/27/1657821.html

SQLite数据库是中小站点CMS的极品选项:
http://www.dbanotes.net/database/sqlite_cms.html

SQLite的局限性:
http://dev.firnow.com/course/7_databases/sql/sqlServer/200838/103309.html

sqlite常见问题:
http://dev.firnow.com/course/7_databases/sql/sqlServer/200838/103310.html

MySQL大战SQLite(PostgreSQL强势乱入):http://obmem.com/?p=493


★SQLite技术上之长处和特征

  SQLite是一个轻量级、跨平台的涉及项目数据库。既然号称关系项目数据库,支持SQL92专业中常用的玩具(比如视图、事务、触发器等)就是当然的了,咱今天便不细说了。今天要聊聊一些略带特色的玩具。

  ◇轻量级
  先说它们的第一个性状:轻量级。想必SQLite的作者非常强调这特性,连其的Logo都是用底“羽毛”,来突显摆它的轻。
SQLite和C/S模式的数据库软件不同,它是经过内之数据库引擎,因此不在数据库的客户端与服务器。使用SQLite一般才需要带达它的一个动态库,就可大饱眼福它的整职能。而且死动态库的尺寸为非常聊,3.6.27本子也就是几百K

  ◇绿色软件
SQLite的另外一个特点是绿色:它的为主引擎本身不靠第三着的软件,使用它们也不需要“安装环境”(如:Oledb等)。所以在配置之下能节约不少麻烦。

  ◇单一文件
所谓的“单一文件”,就是数据库被负有的音讯(比如表、视图、触发器、等)都蕴涵在一个文书内。这个文件可以copy到外目录或另机器上,也照用不误。

  ◇跨平台/可移植性
  如果光支持主流操作系统(Windows,Linux),那就是没有啥好鼓吹的了。除了主流操作系统,SQLite还支持了无数小型嵌入式系统,比如Android、Windows
Mobile、Symbin、Palm、VxWorks等,也就是说iPhone,Android等手机上都得以据此。

  ◇内存数据库(in-memory database)
这年头,内存越来越便利,很多平凡PC都起以GB为单位来衡量内存(服务器就再度不要提了)。这时候,SQLite的内存数据库特性就是越显得好用。
SQLite的API不区分当前操作的数据库是于内存还是于文书(对于存储介质是晶莹剔透的)。所以若您道磁盘I/O有或变为瓶颈的话,可以设想切换为内存方式。切换的时段,操作SQLite的代码基本不用大改,只要以开头时将公文Load到内存,结束时拿内存的数库Dump回文件就OK了。在这种状况下,前面提到的“online
backup
API”就派上用场了,聪明的同学应该知道自己为啥这么想backup功能了咔嚓?

★技术及之短处和不足

  前面光聊了特色以及长,为了避免枪手写软文的疑心,再来说说SQLite的局部缺陷。列位看官将来一旦想就此她,这些毛病要衡量一下。

  ◇并发访问的锁机制
SQLite于起(包括多进程同多线程)读写点的特性一直不极端出色。数据库可能会见吃写操作独占,从而致使其他读写操作阻塞或错。

  ◇SQL标准支持不都
在它的官方网站上,具体列举了非支持什么SQL92正式。我个人感觉比较难过的是无支持外键约束。

  ◇网络文件系统(以下简称NFS)
  有时候要拜访其它机器及之SQLite数据库文件,就会管数据库文件放置到网络共享目录上。这时候若将小心了。当SQLite文件放置于NFS时,在出现读写的情形下或者会见出题目(比如数据损坏)。原因据说是出于某些NFS的文件锁实现上生Bug。

★编程语言接口

  SQLite支持特别多种语言的编程接口。这对于自己这种好混用多种编程语言的丁来说,是非常凉爽的。下面我大体介绍一下。

  ◇C/C++
  由于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,不过自己耶未尝因此了。