🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
在百宝云当中,SQLite数据库是支持的,它是一种轻量级的数据库,方便用户移动与使用。在小项目里面,推荐大家使用这个数据库来存储数据、查询数据。下面我们来详细的介绍下这个SQLite数据库。 ## 官方教程 - SQLite数据库的使用 **百宝云之Sqlite数据库的SQL语句总结**: http://bbs.tyuyan.net/thread-54778-1-1.html 官方的教程里,包含了视频教程与源码示例,大家可以根据视频与示例来理解与掌握这个SQLite数据库的使用。 ## SQLite数据库的含义 SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源的世界著名数据库管理系统来讲,它的处理速度比他们都快。SQLite第一个Alpha版本诞生于2000年5月。 至2015年已经有15个年头,SQLite也迎来了一个版本 SQLite 3已经发布。 ## 工作原理 不像常见的客户-服务器范例,SQLite引擎不是个程序与之通信的独立进程,而是连接到程序中成为它的一个主要部分。所以主要的通信协议是在编程语言内的直接API调用。这在消耗总量、延迟时间和整体简单性上有积极的作用。整个数据库(定义、表、索引和数据本身)都在宿主主机上存储在一个单一的文件中。它的简单的设计是通过在开始一个事务的时候锁定整个数据文件而完成的。 ## 功能特性 1. ACID事务 2. 零配置 – 无需安装和管理配置 3. 储存在单一磁盘文件中的一个完整的数据库 4. 数据库文件可以在不同字节顺序的机器间自由的共享 5. 支持数据库大小至2TB 6. 足够小, 大致13万行C代码, 4.43M 7. 比一些流行的数据库在大部分普通数据库操作要快 8. 简单, 轻松的API 9. 包含TCL绑定, 同时通过Wrapper支持其他语言的绑定 10. 良好注释的源代码, 并且有着90%以上的测试覆盖率 11. 独立: 没有额外依赖 12. 源码完全的开源, 你可以用于任何用途, 包括出售它 13. 支持多种开发语言,C, C++, PHP, Perl, Java, C#,Python, Ruby等 SQLite虽然很小巧,但是支持的SQL语句不会逊色于其他开源数据库,它支持的SQL包括: ~~~ ATTACH DATABASE BEGIN TRANSACTION comment COMMIT TRANSACTION COPY CREATE INDEX CREATE TABLE CREATE TRIGGER CREATE VIEW DELETE DETACH DATABASE DROP INDEX DROP TABLE DROP TRIGGER DROP VIEW END TRANSACTION EXPLAIN expression INSERT ON CONFLICT clause PRAGMA REPLACE ROLLBACK TRANSACTION SELECT UPDATE ~~~ 同时它还支持事务处理功能等等。也有人说它象Microsoft的Access,有时候真的觉得有点象,但是事实上它们区别很大。比如SQLite 支持跨平台,操作简单,能够使用很多语言直接创建数据库,而不象Access一样需要Office的支持。如果你是个很小型的应用,或者你想做嵌入式开发,没有合适的数据库系统,那么你可以考虑使用SQLite。到2013年10月17日最新版本是 3.8.1 。能在上面获得源代码和文档。同时因为数据库结构简单,系统源代码也不是很多,也适合想研究数据库系统开发的专业人士。 ## 数据类型 SQLite的数据类型 首先你会接触到一个让你惊讶的名词: Typelessness(无类型), 对! SQLite是无类型的,这意味着你可以保存任何类型的数据到你所想要保存的任何表的任何列中, 无论这列声明的数据类型是什么(只有在一种情况下不是, 稍后解释),对于SQLite来说对字段不指定类型是完全有效的。 如: ~~~ Create Table ex1(a, b, c); ~~~ 诚然SQLite允许忽略数据类型, 但是仍然建议在你的Create Table语句中指定数据类型, 因为数据类型对于你和其他的程序员交流,或者你准备换掉你的数据库引擎时能起到一个提示或帮助的作用, SQLite支持常见的数据类型。如: ~~~ CREATE TABLE ex2 a VARCHAR(10), b NVARCHAR(15), c TEXT, d INTEGER, e FLOAT, f BOOLEAN, g CLOB, h BLOB, i TIMESTAMP, j NUMERIC(10,5) k VARYING CHARACTER (24), l NATIONAL VARYING CHARACTER(16) ~~~ 前面提到在某种情况下,SQLite的字段并不是无类型的, 即在字段类型为”Integer Primary Key”时。 ## 客户端管理 SQLite亦可以作为桌面数据库使用,以下为第三方SQLite的GUI软件 。例如: SQLiteMan,使用QT开发的一个SQLite客户端,支持多语言、跨平台。 SQLiteSpy 轻量级的SQLite客户端,免费,单文件,界面设计紧凑,很稳定, 功能相对较少,创建表与添加数据均需sql语句,作为数据浏览和修改工具极佳。 SQLite Manager, 以火狐浏览器的扩展形式提供的SQLite客户端 。 本人推荐大家使用:SqliteStudio,使用教程与软件下载见: http://bbs.baibaoyun.com/thread-32-1-1.html ## SQLite 常用函数 SQLite 有许多内置函数用于处理字符串或数字数据。下面列出了一些有用的 SQLite 内置函数,且所有函数都是大小写不敏感,这意味着您可以使用这些函数的小写形式或大写形式或混合形式。欲了解更多详情,请查看 SQLite 的官方文档: 序号 函数 & 描述 1. SQLite COUNT 函数 SQLite COUNT 聚集函数是用来计算一个数据库表中的行数。 2. SQLite MAX 函数 SQLite MAX 聚合函数允许我们选择某列的最大值。 3. SQLite MIN 函数 SQLite MIN 聚合函数允许我们选择某列的最小值。 4. SQLite AVG 函数 SQLite AVG 聚合函数计算某列的平均值。 5. SQLite SUM 函数 SQLite SUM 聚合函数允许为一个数值列计算总和。 6. SQLite RANDOM 函数 SQLite RANDOM 函数返回一个介于 -9223372036854775808 和 +9223372036854775807 之间的伪随机整数。 7. SQLite ABS 函数 SQLite ABS 函数返回数值参数的绝对值。 8. SQLite UPPER 函数 SQLite UPPER 函数把字符串转换为大写字母。 9. SQLite LOWER 函数 SQLite LOWER 函数把字符串转换为小写字母。 10. SQLite LENGTH 函数 SQLite LENGTH 函数返回字符串的长度。 11. SQLite sqlite_version 函数 SQLite sqlite_version 函数返回 SQLite 库的版本。