zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

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

SQLite入门教程 删除 创建 修改
2023-06-13 09:15:14 时间

一、数据库定义语言DDL

在关系型数据库中,数据库中的表Table、视图View、索引Index、关系Relationship和触发器Trigger等等,构成了数据库的架构Schema。在SQL语句中,专门有一些语句用来定义数据库架构,这些语句被称为“数据库定义语言”,即DDL。

SQLite数据库引擎支持下列三种DDL语句:

复制代码代码如下:


CREATE
ALTERTABLE
DROP

其中,CREATE语句用来创建表Table、视图View、索引Index、关系Relationship和触发器Trigger,DROP语句用来删除表Table、视图View、索引Index、关系Relationship和触发器Trigger,ALTERTABLE语句用来改变表的结构。

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

二、SQLite中的数据类型

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

NULL-空值
INTEGER-有符号整数
REAL-浮点数
TEXT-文本字符串
BLOB-二进制数据,如图片、声音等等
SQLite也可以接受其他数据类型。

三、创建表CREATETABLE

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

复制代码代码如下:


myqiao@ubuntu:~$sqlite3test.db
--Loadingresourcesfrom/home/myqiao/.sqliterc
SQLiteversion3.7.4
Enter".help"forinstructions
EnterSQLstatementsterminatedwitha";"
sqlite>.tables
sqlite>

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

下面我们创建一个Student表,其中包含Id、Name、Age等字段.

复制代码代码如下:
sqlite>
sqlite>CREATETABLEStudents(Idinteger,Nametext,ageinteger);
sqlite>.tables
Students
sqlite>.schemaStudents
CREATETABLEStudents(Idinteger,Nametext,ageinteger);
sqlite>

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

四、修改表ALTERTABLE

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

改变表名-ALTERTABLE旧表名RENAMETO新表名
增加一列-ALTERTABLE表名ADDCOLUMN列名数据类型限定符
下面我们来演示一下,将前面的Students表的名字改为Teachers

复制代码代码如下:
sqlite>
sqlite>.tables
Students
sqlite>ALTERTABLEStudentsRENAMETOTeachers;
sqlite>.tables
Teachers
sqlite>

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

下面改变Teachers表的结构,增加一个Sex列

复制代码代码如下:
sqlite>
sqlite>.schemaTeachers
CREATETABLE"Teachers"(Idinteger,Nametext,ageinteger);
sqlite>ALTERTABLETeachersADDCOLUMNSextext;
sqlite>.schemaTeachers
CREATETABLE"Teachers"(Idinteger,Nametext,ageinteger,Sextext);
sqlite>

五、删除表DROPTABLE

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

删除表-DROPTABLE表名
下面,我们将test.db中的Teachers表删除

复制代码代码如下:
sqlite>
sqlite>.tables
Teachers
sqlite>DROPTABLETeachers;
sqlite>.tables
sqlite>

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

六、后续内容

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