SQLite 技术专题简介-编程知识网

简介

SQLite开发者D. Richard Hipp(英语:D. Richard Hipp)首次发布2000年8月17日,​22年前​(2000-08-17)当前版本3.41.2 (2023年3月22日;稳定版本) 源代码库www.sqlite.org/src 编程语言ANSI C操作系统跨平台文件大小小于600KiB语言英语类型关系型数据库(嵌入式)许可协议公有领域网站sqlite.org SQLite数据库文件格式扩展名.sqlite, .sqlite3, .db, .db3, .s3db, .sl3互联网媒体类型application/vnd.sqlite3魔术数字53 51 4c 69 74 65 20 66 6f 72 6d 61 74 20 33 00(零终结的ASCII “SQLite format 3″)初始版本2004-06-18自由格式?是的(共有领域)网站www.sqlite.org/fileformat2.htmlSQLite(/ˌɛskjuːɛlˈlaɪt/或/ˈsiːkwəl.laɪt/)是遵守ACID的关系数据库管理系统,它包含在一个相对小的C程序库中。与许多其它数据库管理系统不同,SQLite不是一个客户端/服务器结构的数据库引擎,而是被集成在用户程序中。SQLite遵守ACID,实现了大多数SQL标准。它使用动态的、弱类型的SQL语法。它作为嵌入式数据库,是应用程序,如网页浏览器,在本地/客户端存储数据的常见选择。它可能是最广泛部署的数据库引擎,因为它正在被一些流行的浏览器、操作系统、嵌入式系统所使用。同时,它有许多程序设计语言的语言绑定。SQLite是D. Richard Hipp(英语:D. Richard Hipp)创建的公有领域项目。

设计

不像常见的客户端/服务器结构数据库管理系统,SQLite引擎不是一个应用程序与之通信的独立进程。SQLite库链接到程序中,并成为它的一个组成部分。这个库也可被动态链接。应用程序经由编程语言内的直接API调用来使用SQlite的功能,这在减少数据库访问延迟上有积极作用,因为在一个单一进程中的函数调用比跨进程通信更有效率。SQLite将整个数据库,包括定义、表、索引以及数据本身,作为一个单独的、可跨平台使用的文件存储在主机中。它采用了在写入数据时将整个数据库文件加锁的简单设计。尽管写操作只能串行进行,但SQLite的读操作可以多任务同时进行。

SQLite将PostgreSQL作为参考平台。项目将“PostgreSQL可能做些什么”作为SQL标准实现的开发参考。然而与这个目标最重要的偏差在于,除了主键以外,SQLite不强制进行类型检查。一个值的类型是动态的,不被schema所强制限制(虽然如此,但如果可以进行可恢复的类型转换时,schema会在存储数据时触发一个自动转换)。

特征

程序库实现了多数的SQL-92标准,包括事务,以及实现原子性、一致性、隔离性和持久性(即ACID),但它缺失了某些特性。例如,它仅部分支持触发器。尽管它支持大多数的复杂查询,但它的ALTER TABLE功能有所限制,不能修改或删除列,只能通过重新创建表的方式迂回进行。

SQLite不进行类型检查。你可以把字符串插入到整数列中。某些用户发现这是使数据库更加有用的创新,特别是与无类型的脚本语言一起使用的时候;然而其他用户认为这是主要的缺点。

多个进程或线程可以同时访问同一个数据而没有问题。可以同时平行读取同一个数据库。但同一时间只能有一个进程或线程进行数据写入;否则会写入失败并得到一个错误消息(或者会自动重试一段时间;自动重试的逻辑以及重试时间的长短是可以设置的)。

程序设计者还提供了一个叫做sqlite3的独立程序用来查询和管理SQLite数据库文件。SQLite的用户可以把这个程序当作如何写SQLite应用程序的示例。

语言绑定

目前有大量的编程语言提供使用SQLite的绑定,包括:

C/C++

C#与VB.Net以Mono实现,需要.NET Framework4.0以上版本,并支持Entity Framework

Tcl

在CPAN的DBD::SQLite上有一个Perl的DBI/DBD模块,它不是到SQLite的接口,而是包括整个SQLite数据库引擎在其中并不需要任何额外的软件。

Python自2.5之后将pysqlite内置,模块名为sqlite3(import sqlite3;下载的package名为pysqlite3)。

PHP从PHP 5.0开始已经包含SQLite,但是自5.1版之后,SQLite开始成为一个延伸库。SQLite能与PHP4一起工作,但不包含在PHP4里面。

Rails2.0.3将缺省的数据库配置改为了SQLite 3。

Haskell

Java

Delphi: DISQLite3作为Delphi的一个第三方控件,不是SQLite的API,也不是接口,而是把SQLite数据库引擎重新封装编译到Delphi的目标程序中。

SQLite管理客户端

SQLite亦可以作为桌面数据库使用,以下为第三方SQLite的GUI软件。例如,

Navicat for SQLite是一套专为SQLite设计的强大数据库管理及开发工具。它可以用于任何版本2或3的SQLite数据库,并支持大部分SQLite的功能,包括触发器、索引、查看等。

SQLiteMan,使用Qt开发的一个SQLite客户端,支持多语言、跨平台。

Firefox,可以借由安装扩展成为SQLite客户端管理工具,包括SQLite Manager、SQLite Reader、SQLite Manager(另一个同名的WebExtensions扩展)。

SQLite Database Browser,一款连接SQLite数据库的图形客户端。

SQLite Expert Personal,Windows上的一款连接SQLite数据库的免费客户端。

Database .NET,一套适用于 Windows 平台的免安装绿色软件,支持多种可视化数据库管理工具,除了 SQLite 之外也支持 Microsoft SQL Server、SQL Azure、MySQL、Oracle、IBM DB2、Informix、PostgreSQL、HP Vertica、NuoDB、Teradata、Sybase ASE、Firebird、Access、Excel、DBase、SQLCe… 等数据库软件。