在百宝云当中,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 库的版本。
- 前言 关于百宝云企业版
- 第一章 企业版性能与价格介绍
- 购买服务器流程
- 企业版服务器配置篇
- 注册成为企业版用户
- 主服务器的配置流程
- 从服务器的配置流程
- 第六章 用户使用手册篇
- 云应用使用相关篇
- 创建云应用
- 编辑与更新云应用代码
- 增加访问人数(并发数)
- 增加长连接个数
- MySQL数据库的使用方法
- SQLite数据库使用方法
- 用户注册管理篇
- 开放注册的设置
- 注册的默认设置
- 对注册用户的全局控制
- 对用户安装包位置的控制管理
- 对用户云应用的控制管理
- 对用户数据库的控制管理
- 对用户云盘空间的控制管理
- 新增服务器操作篇
- 新增Get/Post服务器流程
- 新增MySQL服务器流程
- 新增虚拟桌面服务器流程
- 新增路由服务器流程
- 新增接入服务器流程
- 新增在线服务器流程
- 新增下载服务器流程
- 新增云应用服务器流程
- 服务器功能描述篇
- 扩充磁盘的操作流程
- 接入百宝云相关篇
- 自己项目接入百宝云的注意事项
- TC项目接入的方法
- VC++接入方法
- 易语言接入方法
- 按键精灵(PC版)接入方法
- 安卓(Android)接入方法
- IOS接入方法
- PHP接入方法
- 使用软件的自动更新
- 表单报表相关篇
- 第二章 管理员使用手册篇
- 如何进入管理者后台
- 全局设置面板
- 站点信息设置
- 用户注册的基本设置
- 安装包位置设置
- 数据库设置
- 系统更新的介绍
- 用户管理面板
- 用户管理列表
- 用户登录日志
- 实名认证管理
- 云应用管理面板
- 云应用列表
- 访问token管理
- 安装包位置管理
- 数据库管理面板
- MySQL服务器配置
- 用户数据库信息
- 工单管理面板
- 待处理工单列表
- 已处理工单列表
- 工单分类说明
- 服务器管理面板
- 服务器总览图
- 服务器管理页面介绍
- 服务器各功能的介绍
- 云应用服务器
- COM路由服务
- COM接入服务
- COM在线服务
- COM下载服务
- MySQL数据库服务
- 虚拟桌面服务
- GetPost服务
- 云系统磁盘管理面板
- 云磁盘管理
- 用户云系统管理
- 第三章 虚拟桌面说明篇
- 云虚拟桌面说明
- 默认桌面图标的简介
- 云应用右键菜单的介绍
- 消息与个性化设置
- 文件管理说明
- 编辑器说明
- 云应用管理说明
- 云应用信息
- 云数据库管理
- 日志错误管理
- 应用设置管理
- 百宝云管理说明
- 用户中心
- 云应用
- 云应用管理
- 访问token管理
- 安装包位置管理
- 安装包位置生成
- 安全组管理
- 云盘管理
- 数据库
- 数据库信息
- 数据库的安装
- 短信服务
- 工单服务
- 安全中心
- 第四章 联系人管理篇
- 联系人介绍
- 联系人的权限管理
- 第五章 报表使用说明篇
- 表单使用说明
- 附件一 关键字说明篇
- 安装包位置是什么
- 安装包是什么
- 云应用是什么
- 磁盘(云盘)是什么
- SQLite数据库是什么
- MySQL数据库是什么
- 访问人数(并发数)是什么
- 长连接个数是什么
- 附件二 常见问题
- 如何成为百宝云用户
- 如何成为企业版用户(管理员)
- 如何变配云应用
- 如何变配企业版
- 如何变配数据库
- 安装包位置操作失败的解决方案