博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQLite之基础篇
阅读量:6648 次
发布时间:2019-06-25

本文共 4258 字,大约阅读时间需要 14 分钟。

1、SQLite3简介

SQLite是嵌入式关系型数据库引擎。它是一个独立的、无服务器、零配置、事务型SQL数据库引擎。它流行世界各地,被用于Solaris 10、Mac OS、Android、iPhone中。Qt4、Python、PHP都有内置的SQLite。许多流行的应用也都使用SQLite,如Firefox、Google Chrome、Amarok。适合桌面程序和小型网站的数据库服务器。SQLite直接读写在硬盘上的数据库文件。

优势

  1. 易于管理,甚至可以认为是无需管理。

  2. 操作方便,SQLite生成的数据库文件可在各个平台无缝移植。

  3. 可以多种形式嵌入到的其它应用程序中,如静态库、动态库等。

  4. 易于维护和配置,为零配置。完整配置的少于 250KB,忽略一些可选特性的少于 150KB。

  5. 没有独立的服务器,其运行环境与主程序位于同一进程空间,因此它们之间的通信完全是进程内通信,而相比于进程间通信,其效率更高。

  6. 单一磁盘文件,只要有权限便可随意访问和拷贝,便于携带和共享。

劣势

  1. 由于SQLite的数据管理机制更多的依赖于OS的文件系统,因此在多用户访问数据库数据时,特别是数据操作通过网络传输完成时,其效率较低。

  2. 受限于操作系统的文件系统,处理大数据时,效率较低,对于超大数据量,甚至不能支持。支持最大可达 2T 的数据库。

  3. SQLite仅仅提供了粒度很粗的数据锁,如读写锁,因此在每次加锁操作中都会有大量的数据被锁住,即仅有极小部分的数据会被访问。在这种同步机制下,并发性能很难高效。

在gentoo下安装SQLite3:

$ sudo emerge -avt dev-db/sqlite

2、SQL(Structured Query Language)语言基本语法

2.1 数据库操作

1) 新建数据库

$ sqlite3 test.dbSQLite version 3.8.11.1 2015-07-29 20:00:57Enter ".help" for usage hints.sqlite>

2) 数据库备份

sqlite3 test.db .dump > test.sql //数据库备份

或者

sqlite> .output test.sqlsqlite> .dumpsqlite> .exit

3) 导入一个备份

sqlite3 test.db < test.sql

4) 卸载将当前连接中的指定数据库

sqlite> DETACH DATABASE mydb;

5) ATTACH DATABASE语句

添加另外一个数据库文件到当前的连接中,":memory:"为内存数据库。

sqlite> ATTACH DATABASE '~/tmp/mydb.db' AS mydb;

2.2 创建数据表

1) 最简单的数据表

sqlite> CREATE TABLE testtable (first_var integer);

注意:testtable不要以sqlite_开头,因为该前缀定义的表名都用于sqlite内部.

2) 创建带有缺省值的数据表

sqlite> CREATE TABLE testtable (first_col integer DEFAULT 0, second_col varchar DEFAULT 'hello');

3) 在指定数据库创建表

sqlite> ATTACH DATABASE '~/tmp/mydb.db' AS mydb;//mydb.db不一定存在sqlite> CREATE TABLE mydb.testtable (first_col integer);

4) IF NOT EXISTS从句

如果你要创建的数据表已存在,则使用之前的创建表语句会发生错误,这就需要加上IF NOT EXISTS从句.

sqlite> CREATE TABLE IF NOT EXISTS testtable (first_col integer);

5) CREATE TABLE ... AS SELECT

新创建的表将会包含SELECT查询返回的结果集的所有数据,但是不包含缺省值和主键等约束信息。

sqlite> CREATE TABLE testtable2 AS SELECT * FROM testtable;sqlite> .schema testtable2CREATE TABLE testtable2(first_col INT);

6) 主键约束:

sqlite> CREATE TABLE testtable (first_col integer PRIMARY KEY ASC);//ASC

联合主键

sqlite> CREATE TABLE testtable2 (first integer, second integer, PRIMARY KEY (first_col,second_col));

7) 唯一性约束

sqlite> CREATE TABLE testtable (first_col integer UNIQUE);

两个列的唯一性约束

sqlite> CREATE TABLE testtable2 (first integer, second integer, UNIQUE (first_col,second_col));

8) 为空(NOT NULL)约束

sqlite> CREATE TABLE testtable(first_col integer NOT NULL);

9) 检查性约束

sqlite> CREATE TABLE testtable (first_col integer CHECK (first_col < 5));

2.3 数据表的修改

1) 修改表名

SQLite中表名的修改只能在同一个数据库,表名被修改后,该表已存在的索引将不会受到影响,然而依赖该表的视图和触发器将不得不重新修改其定义。

sqlite> ALTER TABLE testtable RENAME TO testtable2;

2) 新增字段

sqlite> ALTER TABLE testtable ADD COLUMN second_col integer;

2.4 表的删除

sqlite> DROP TABLE testtable;sqlite> DROP TABLE IF EXISTS testtable;

2.5 插入数据

sqlite> INSERT INTO testtable VALUES(2);

2.6 显示数据表的数据

为了增减输出的易读性

sqlite> .echo onsqlite> .mode onsqlite> .headers onsqlite> .nullvalue NULL

显示语法

sqlite> SELECT * FROM testtablel;sqlite> SELECT fisrt FROM testtablel;

2.7 数据表中数据的操作

1) 更新数据表里的某些数据

sqlite> UPDATE testtable SET first=2 WHERE ID = 1;

2) 删除数据表中的全部数据

sqlite> DROP FROM testtable;

3) 删除数据表中的某些数据

sqlite> DROP FROM testtable WHERE ID = 1 AND NAME = yxg;

2.8 事务:

如果没有为当前的SQL命令(SELECT除外)显示的指定事务,那么SQLite会自动为该操作添加一个隐式的事务,以保证该操作的原子性和一致性。

sqlite> BEGIN TRANSACTION;sqlite> INSERT INTO testtable VALUES(1);sqlite> INSERT INTO testtable VALUES(2);sqlite> COMMIT TRANSACTION;--显示事务被提交,数据表中的数据也发生了变化。sqlite> SELECT COUNT(*) FROM testtable;COUNT(*)2sqlite> BEGIN TRANSACTION;sqlite> INSERT INTO testtable VALUES(1);sqlite> ROLLBACK TRANSACTION; --显示事务被回滚,数据表中的数据没有发生变化。sqlite> SELECT COUNT(*) FROM testtable;COUNT(*)2

3、数据类型

3.1 存储种类

SQLite将数据值的存储划分为以下几种存储类型:

NULL: 表示该值为NULL值。
INTEGER: 无符号整型值。
REAL: 浮点值。
TEXT: 文本字符串,存储使用的编码方式为UTF-8、UTF-16BE、UTF-16LE。
BLOB: 存储Blob数据,该类型数据和输入数据完全相同。

3.2 比较表达式

"=", "==", "<", "<=", ">", ">=", "!=", "<>", "IN", "NOT IN", "BETWEEN", "IS" and "IS NOT"。

4、命令行工具

.help //列出所有内置命令

.tables TABLENAME //显示当前连接的数据库中的所有数据表,若指定表名,仅显示匹配的数据表,TABLENAME支持LIKE表达式。
.backup ~/tmp/test.db //将当前连接中的缓存数据导出到本地文件。
.schema //是sqlite3命令行工具的内置命令,用于显示当前数据表的CREATE TABLE语句。
.exit //退出当前连接。
.databases //列出当前链接中所有attached数据库名和文件名。
.echo ON|OFF //打开或关闭显示输出。
.header(s) ON|OFF //在显示SELECT结果时,是否显示列的标题。
.import FILE TABLE //导入指定文件到指定表。
.mode MODE TABLENAME //设置输出模式,常用为column,是SELECT输出列左对齐显示。
.read FILENAME//执行指定文件内的SQL语句。

转载地址:http://mvyto.baihongyu.com/

你可能感兴趣的文章
腾讯大规模分布式机器学习系统无量是如何进行技术选型的?
查看>>
性能之巅:Linux网络性能分析工具
查看>>
敏捷组织中项目管理办公室(PMO)的角色
查看>>
V8提升异步性能:JavaScript一大痛点得以解决
查看>>
Confluent平台5.0支持LDAP授权及用于IoT集成的MQTT代理
查看>>
比其他行业晚了十年的工业软件,转型的核心和动力是什么?
查看>>
MAC Androidstudio打开移动硬盘项目
查看>>
Istio:一个用于微服务间通信的服务网格开源项目
查看>>
.NET Core 2.1预览版首次引入Global Tools
查看>>
我是一个码农
查看>>
Golang redis 操作初体验
查看>>
Fastreport.Net用户手册(十):打印Bands
查看>>
HTTP 响应头与状态码
查看>>
javascript常用方法函数收集(一)
查看>>
docker网络方案简介
查看>>
window.scrollTo()函数注意点(js)
查看>>
Mac:更好地工作 - 应用内快捷键
查看>>
原型链是什么?关于原型链中constructor、prototype及__proto__之间关系的认识
查看>>
Android小技巧:自动初始化Library
查看>>
[jQuery]jQuery DataTables插件自定义Ajax分页实现
查看>>