一、数据库定义语言 DDL
在关系型数据库中,数据库中的表 Table、视图 View、索引 Index、关系 Relationship 和触发器 Trigger 等等,构成了数据库的架构Schema。 在SQL语句中,专门有一些语句用来定义数据库架构,这些语句被称为“数据库定义语言”,即 DDL。
SQLite 数据库引擎支持下列三种DDL语句:
CREATEALTER TABLEDROP其中,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:~$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 命令。
四、修改表 ALTER TABLE
SQLite 仅仅支持 ALTER TABLE 语句的一部分功能,我们可以用 ALTER TABLE 语句来更改一个表的名字,也可向表中增加一个字段(列),但是我们不能删除一个已经存在的字段,或者更改一个已经存在的字段的名称、数据类型、限定符等等。
改变表名 – ALTER TABLE 旧表名 RENAME TO 新表名增加一列 – ALTER TABLE 表名 ADD COLUMN 列名 数据类型 限定符下面我们来演示一下,将前面的 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>
五、删除表 DROP TABLE
删除一个表很简单,只要给出表名即可
删除表 – DROP TABLE 表名下面,我们将 test.db 中的 Teachers 表删除
sqlite> sqlite>.tables Teachers sqlite>DROPTABLETeachers; sqlite>.tables sqlite>
删除 Teachers 表后再运行 .tables 命令,发现数据库已经空了。
到此本文已经介绍完毕了,若文中存在不妥之处,欢迎各位批评指正,谢谢大家的支持!
【编辑推荐】
- 开发BI系统时的需求分析研究嵌入式数据库Sqlce读取数据过程简介微软WP7本地数据库之SQLite编程技巧微软WP7本地数据库之Sterling编程技巧如何不使用数据库缓存,还达到实时更新