当前位置: 移动技术网 > IT编程>数据库>SQLLite > SQLite 入门教程二 SQLite的创建、修改、删除表

SQLite 入门教程二 SQLite的创建、修改、删除表

2017年12月08日  | 移动技术网IT编程  | 我要评论

一、数据库定义语言 ddl

在关系型数据库中,数据库中的表 table、视图 view、索引 index、关系 relationship 和触发器 trigger 等等,构成了数据库的架构 schema。 在 sql 语句中,专门有一些语句用来定义数据库架构,这些语句被称为“数据库定义语言”,即 ddl。

sqlite 数据库引擎支持下列三种 ddl 语句:

复制代码 代码如下:

create
alter table
drop

其中,create 语句用来创建表 table、视图 view、索引 index、关系 relationship 和触发器 trigger, drop语句用来删除表 table、视图 view、索引 index、关系 relationship 和触发器 trigger, alter table 语句用来改变表的结构。

今天这一篇只涉及到表的相关内容,视图、触发器等到后面再讲。

二、sqlite 中的数据类型

sqlite 数据库中的数据一般由以下几种常用的数据类型组成:

null - 空值
integer - 有符号整数
real - 浮点数
text - 文本字符串
blob - 二进制数据,如图片、声音等等
sqlite 也可以接受其他数据类型。

三、创建表 create table

首先,创建一个 test.db 数据库并进入 sqlite 命令行环境,还记得怎么做吗?

复制代码 代码如下:

myqiao@ubuntu:~$ sqlite3 test.db
-- loading resources from /home/myqiao/.sqliterc
sqlite version 3.7.4
enter ".help" for instructions
enter sql statements terminated with a ";"
sqlite> .tables
sqlite>

向上面这样,我们就在终端中创建了一个 test.db 数据库,并且通过 .tables 命令查询数据库中的表,结果没有任何返回,因为数据库本来就是空的嘛。

下面我们创建一个 student 表,其中包含 id、name、age 等字段.

复制代码 代码如下:

sqlite>
sqlite> create table students(id integer,name text,age integer);
sqlite> .tables
students
sqlite> .schema students
create table students(id integer,name text,age integer);
sqlite>

向上面这样,一个 students 表就被建立了,这回再运行 .tables 命令就有响应了,系统告诉我们数据库中现在有一个 students 表, 运行 .schema 命令,返回了我们创建这个表的 sql 命令。

四、修改表 alter table

sqlite 仅仅支持 alter table 语句的一部分功能,我们可以用 alter table 语句来更改一个表的名字,也可向表中增加一个字段(列),但是我们不能删除一个已经存在的字段,或者更改一个已经存在的字段的名称、数据类型、限定符等等。

改变表名 - alter table 旧表名 rename to 新表名
增加一列 - alter table 表名 add column 列名 数据类型 限定符
下面我们来演示一下,将前面的 students 表的名字改为 teachers

复制代码 代码如下:

sqlite>
sqlite> .tables
students
sqlite> alter table students rename to teachers;
sqlite> .tables
teachers
sqlite>

原来数据库中只有一个 students 表,改名以后再运行 .tables 命令,发现 students 表已经没了,现在变成了 teachers 表。

下面改变 teachers 表的结构,增加一个 sex 列

复制代码 代码如下:

sqlite>
sqlite> .schema teachers
create table "teachers"(id integer,name text,age integer);
sqlite> alter table teachers add column sex text;
sqlite> .schema teachers
create table "teachers"(id integer,name text,age integer, sex text);
sqlite>

五、删除表 drop table

删除一个表很简单,只要给出表名即可

删除表 - drop table 表名
下面,我们将 test.db 中的 teachers 表删除

复制代码 代码如下:

sqlite>
sqlite> .tables
teachers
sqlite> drop table teachers;
sqlite> .tables
sqlite>

删除 teachers 表后再运行 .tables 命令,发现数据库已经空了。

六、后续内容

其实创建一个表远没有这么简单,表的每一列可以有很多限定符,比如主列、非空、限制、默认值、唯一、键等等,这些内容留到下一篇吧

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网