本文紧张讲解数据库SQLite,通过这个开源的小型的嵌入式数据库带领大家节制一些基本的数据库操作,这些操作在很多系统中都是通用的,可谓学一通百。

SQLite

SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。

作者D.RichardHipp

2000年1月,Hipp开始和一个同事谈论关于创建一个大略的嵌入式SQL数据库的想法,这个数据库将利用GNU DBM哈希库(gdbm)做后台,同时这个数据库将不须要安装和管理支持。
后来,一有空闲韶光,Hipp就开始履行这项事情,2000年8月,SQLite 1.0版发布了。
【在此向大神献上我的膝盖!

php使用sqlite3嵌入式数据库sqlite3基本篇根本敕令操作小白一看就懂 RESTful API

它的设计目标是嵌入式的,而且已经在很多嵌入式产品中利用了它,它占用资源非常的低,在嵌入式设备中,可能只须要几百K的内存就够了。
它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序措辞相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源的天下著名数据库管理系统来讲,它的处理速率比他们都快。

SQLite特性零配置一无需安装和管理配置;储存在单一磁盘文件中的一个完全的数据库;数据库文件可以在不同字节顺序的机器间自由共享;支持数据库大小至2TB;足够小,全部源码大致3万行c代码,250KB;比目前盛行的大多数数据库对数据的操作要快。
安装

现在运行的紧张是sqlite3版本,在ubuntu下安装也非常方便。

sudoapt-getinstallsqlitesqlite3安装运用程序sudoapt-getinstalllibsqlite3-dev安装库+头文件,用代码操作数据库必须安装

查看版本号: 输入命令 sqlite3进入操作界面,输入命令.version,即可查看详细版本号。

也可以利用下面命令,安装图形化操尴尬刁难象:

sudoapt-getinstallsqlitebrowser图形化工具建立数据库

除此之外,还可以支配在windows下,本文只谈论ubtuntu下,采取命令行办法来操作数据库。

数据类型

操作数据库,紧张便是操作表,表的每一列内容都有一定数据类型,比如整型值、字符串、布尔型等。

Sqlite3紧张数据类型如下:

数据类型 定义 数据类型 NULL 表示该值为NULL值。
INTEGER 无符号整型值。
REAL 浮点值。
TEXT 文本字符串,存储利用的编码办法为UTF-8、UTF-16BE、UTF-16LE。
BLOB 存储Blob数据,该类型数据和输入数据完备相同,1表示true,0表示false。

同时sqlite3也接管如下的数据类型:

数据类型 定义 smallint 16位的整数。
interger 32位的整数。
decimal(p,s) 精确值p是指全部有几个十进制数,s是指小数点后可以有几位小数。
如果没有特殊指定,则系统会默认为p=5 s=0 。
float 32位元的实数。
double 64位元的实数。
char(n) n 长度的字串,n不能超过 254。
varchar(n) 长度不固定且其最大长度为 n 的字串,n不能超过 4000。
graphic(n) 和 char(n) 一样,不过其单位是两个字节, n不能超过127。
这个形态是为了支持两个字节长度的字体,如中笔墨。
vargraphic(n) 可变长度且其最大长度为n的双字元字串,n不能超过2000 date 包含了 年份、月份、日期。
time 包含了 小时、分钟、秒。
timestamp 包含了 年、月、日、时、分、秒、千分之一秒。

约束

表的每一列都有一些限定属性,比如有的列的数据不能重复,有的则限定数据范围等,约束便是用来进一步描述每一列数据属性的。
SQLite 数据库常用约束如下:

名称 定义 NOT NULL - 非空 UNIQUE 唯一 PRIMARY KEY 主键 FOREIGN KEY 外键 CHECK 条件检讨 DEFAULT 默认

非空 NOT NULL

有一些字段我们可能一时不知到该填些什么,同时它也没设定默认值, 当添加数据时,我们把这样的字段空着不填,系统认为他是 NULL 值。
但是还有其余一类字段,必须被填上数据,如果不填,系统就会报错。
这样的字段被称为 NOT NULL 非空字段,须要在定义表的时候事先声明。

唯一 UNIQUE

除了主列以为,还有一些列也不能有重复值。

主键 PRIMARY KEY

一样平常是整数或者字符串,只要担保唯一就行。
在 SQLite 中,主键如果是整数类型,该列的值可以自动增长。

外键 FOREIGN KEY

我们的数据库中已经有 Teachers 表了,如果我们再建立一个 Students 表, 哀求 Students 表中的每一个学生都对应一个 Teachers 表中的西席。
很大略,只须要在 Students 表中建立一个 TeacherId 字段,保存对应西席的 Id 号, 这样,学生和西席之间就建立了关系。
问题是:我们有可能给学生存入一个不在 Teachers 表中的 TeacherId 值, 而且创造不了这个缺点。
这种情形下,可以把 Students 表中 TeacherId 字段声明为一个外键, 让它的值对应到 Teachers 表中的 Id 字段上。
这样,一旦在 Students 表中存入一个不存在的西席 Id ,系统就会报错。

默认值 DEFAULT

有一些特殊的字段列,在每一条记录中,他的值基本上都是一样的。
只是在个别情形下才改为别的值,这样的字段列我们可以给他设一个默认值。

条件检讨 CHECK

某些值必须符合一定的条件才许可存入,这是就须要用到这个 CHECK 约束。

常用命令

下面先容Shell模式中的各常用命令的利用。

命令 功能 .help 可显示shell模式中可利用的所有命令列表 .database 显示数据库信息;包含当前数据库的位置 .mode column 使得SQL语句处理的结果以列对齐的办法显示 .mode list column .headers on/off 打开关闭列标题显示开关,以使得查询结果在屏幕显示时具有列标题 .tables 列出当前打开的数据库中共有多少张表 .exit 退出SQLite环境 .schema foods 显示表foods 创建时的SQL语句 .schema 显示所有表被创建时的语句 .nullvalue STRING 查询时用指定的串代替输出的NULL串 默认为.nullvalue '' .show 显示shell模式中定义的与输出干系的一些设置 .output file.csv 设置输出文件格式为CSV,文件名为file.csv .separator , 设置select语句输出的列数据间以“ ,”分隔 .output stdout 规复输出内容到标准输出设备(屏幕)

【把稳】sqlite的命令都是.开头的,操作语句前面是没有.的。

利用实例

数据库的操作语句紧张是增编削查,下面我们通过一些实例让大家理解数据库的这些基本操作。

表类型

假设我们要创建一个传授教化管理的数据库jxgl.db,数据库中要保存学生表STUDENT。

sno sname ssex sage sdept 95001 yikou m 21 cs 95002 peng m 21 cs

根据我们的知识,可知每一列的数据有以下特性:

sno 学号:整型值,每个人学号是唯一的,学校一样平常用学号来区分所有的学生,而且一样平常学号是递增的,以是我们设置sno为primary key;sname 姓名:一样平常是字符串,可以重复,但是不能为空;ssex 性别:字符串,可以为空;sage 年事:整型值,假定年事要大于14;sdept 专业:字符串,可以为空,此处我们默认为'CS'。

下面我们一步步实现这个数据库的所有操作。

创建传授教化管理“jxgl”数据库

数据库的打开和退出,利用如下命令。

创建表:

CREATETABLEIFNOTEXISTSSTUDENT(Snointegerprimarykey,Snametextnotnull,Ssextext,Sageintegercheck(Sage>14),Sdepttextdefault'CS');

该表的属性便是按照上一节表属性 实行结果:

查看表:

看到STUDENT,解释该表创建好了。
【把稳】

操作语句不是命令,前面不要加. ;操作语句后面一定要;结尾,如果漏掉了,一定要补上分号;操作语句对字母的全角半角很敏感,所有的符号都要用半角。
插入数据

插入数据采取insert into语句来实现,如下所示:

INSERTINTOSTUDENTVALUES('95001','李勇','M',20,'CS');INSERTINTOSTUDENTVALUES('95002','刘晨','F',19,'IS');INSERTINTOSTUDENTVALUES('95003','王敏','F',18,'MA');INSERTINTOSTUDENTVALUES('95004','张立','M',18,'IS');

实行结果如下:

在这里插入图片描述

插入的数据只初始化部分值

设置了not null那一列 必须要赋值,而且表名字不区分大小写。

insertintostudent(sname,sage)values('一口',19);

在这里插入图片描述

查看表

用SELECT语句查看表中的内容:

SELECTFROMSTUDENT;

个中的 表示查看所有的数据信息。

有没有看到,结果看起来不舒畅啊,下面我们来调度下显示格式:

sqlite>.headerson显示列名sqlite>.modecolumn列对齐

在这里插入图片描述

删除一行信息

deletefromstudentwheresname='一口';

由上图可见,名字为“一口”的那条记录被删除了。

修正一条记录的某个内容

UPDATEstudentSETsage=29WHEREsname='张立';

在这里插入图片描述

修正数据表构造。

修正表构造,须要用到语句ALTER TABLE。
下面我们向STUDENT表增加“spwd”列,其数据类型为TEXT型,用SELECT命令查看表中内容。

ALTERTABLESTUDENTADDspwdTEXTdefault'123456';

在这里插入图片描述

修正表名字

altertablestudentrenametostu;

在这里插入图片描述

删除数据表。

DROPTABLESTUDENT;删除列

sqlite3没有实现删除一列的命令,要实现这个操作,须要先将该表拷贝到一个新表,但是只集成须要的列,要删除的列不继续过来。
可以 用以下办法操作删除一列:

sqlite>createtabletestasselectsno,sname,ssex,sage,sdeptfromstu;sqlite>droptablestu;sqlite>altertabletestrenametostu;

由上图可知,我们刚才增加的列spwd被删除了。

sqlite进阶where子句

如果我不想查看所有的数据,而指向查看某一个人的信息要怎么操作呢? 我们就要借助where子句来实现。
where子句可以结合操作语句来进程增编削查,是最常用的一个子句。

根据姓名查找记录:

Selectfromstudentwheresname='一口';

根据学号查找记录:

Selectfromstudentwheresno=95001;

根据姓名和年事同时查找记录:

selectfromstudentwheresname='一口'andsage=19;

显示某两列的数据

selectsno,snamefromstudent;

在这里插入图片描述

数据库的备份和规复

现在我们假设要将表foods备份出为foodsdb.sql,并用命令回答该数据库。
按照以下步骤操作即可。

sqlite>.dump--把创建表及向表中插入记录的所有SQL语句显示在屏幕上sqlite>.outputfoodsdb.sql--指定dump命令输出到文件的文件名sqlite>.dump--输出创建并插入数据到基本表的SQL语句到output指定的文件sqlite>.outputstdout--规复输出内容到标准输出设备(屏幕)sqlite>.dump--此时输出的SQL语句转回到屏幕sqlite>Droptablefoods;--删除foods表语句解释:

上述Drop为SQL语句,用于删除指定的表。
由于是SQL语句,因此以“;”结尾

sqlite>.readfoodsdb.sql--实行foodsdb.sql中的包含的所有SQL语句,用来重修刚删除的4张表及干系数据

好了,随着一口君一步步操作,基本上sqlite3的增编削查操作,相信各位该当没什么问题了,sqlite还有其他一些子句以及函数的用法,留待下一篇连续先容。

获取更多关于Linux的资料,请关注"大众号「一口Linux」