SQLite概述


本章可帮助你了解什么是SQLite,它与SQL有何不同,为什么需要它以及它处理应用程序数据库的方式。

SQLite是一个软件库,可实现自包含,无服务器,零配置的事务型SQL数据库引擎。 SQLite是周围增长最快的数据库引擎之一,但是就受欢迎程度而言,增长是增长的,与其大小无关。 SQLite的源代码位于公共领域。

什么是SQLite?


SQLite是一个进程内库,可实现自包含的,无服务器的,零配置的事务型SQL数据库引擎。它是一个零配置的数据库,这意味着像其他数据库一样,你不需要在系统中对其进行配置。

SQLite引擎不是一个独立于其他数据库的独立进程,你可以根据需要将其静态或动态链接到你的应用程序。 SQLite直接访问其存储文件。

为什么选择SQLite?


  • SQLite不需要单独的服务器进程或系统即可运行(无服务器)。

  • SQLite带有零配置,这意味着不需要设置或管理。

  • 完整的SQLite数据库存储在单个跨平台磁盘文件中。

  • SQLite非常小且重量轻,完全配置的内存小于400KiB,而省略的可选功能则小于250KiB。

  • SQLite是独立的,这意味着没有外部依赖关系。

  • SQLite事务完全兼容ACID,从而允许从多个进程或线程进行安全访问。

  • SQLite支持SQL92(SQL2)标准中的大多数查询语言功能。

  • SQLite用ANSI-C编写,并提供简单易用的API。

  • SQLite在UNIX(Linux,Mac OS-X,Android,iOS)和Windows(Win32,WinCE,WinRT)上可用。

SQLite简史


  • 2000年-D.理查德·希普(R. Richard Hipp)设计SQLite的目的是无需管理程序即可运行程序。

  • 2000年-8月,SQLite 1.0与GNU数据库管理器一起发布。

  • 2011年-Hipp宣布将UNQl接口添加到SQLite DB并开发UNQLite(面向文档的数据库)。

SQLite局限性


下表列出了SQLite中不支持的SQL92功能。

序号.功能与说明
1

右外连接(RIGHT OUTER JOIN)

仅实现了LEFT OUTER JOIN。

2

全外连接(FULL OUTER JOIN)

仅实现了LEFT OUTER JOIN。

3

更改表(ALTER TABLE)

支持ALTER TABLE命令的RENAME TABLE和ADD COLUMN变体。不支持DROP COLUMN,ALTER COLUMN,ADD CONSTRAINT。

4

触发支持(Trigger support)

支持FOR EACH ROW触发器,但不支持FOR EACH STATEMENT触发器。

5

视图(VIEWs)

SQLite中的VIEW是只读的。你可能无法在视图上执行DELETE,INSERT或UPDATE语句。

6

授权和撤销(GRANT and REVOKE)

唯一可以应用的访问权限是基础操作系统的普通文件访问权限。

SQLite命令


与关系数据库进行交互的标准SQLite命令类似于SQL。它们是CREATE,SELECT,INSERT,UPDATE,DELETE和DROP。这些命令可以根据其操作性质分为几类。

DDL-数据定义语言

序号.命令与说明
1

CREATE

在数据库中创建新表,表视图或其他对象。

2

ALTER

修改现有的数据库对象,例如表。

3

DROP

删除整个表,数据库表或其他对象的视图。

DML-数据处理语言

序号.命令与说明
1

INSERT

创建一条记录

2

UPDATE

修改记录

3

DELETE

删除记录

DQL-数据查询语言

序号.命令与说明
1

SELECT

从一个或多个表中检索某些记录