SQLite 创建、修改、删除表
SQLite 创建、修改、删除表一、数据库定义语言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命令行环境,还记得 怎么做吗? [xiazhujie@localhost]:~$sqlite3test.db --Loadingresourcesfrom/home/xiazhujie /.sqliterc SQLiteversion3.7.4 Enter".help"forinstructions EnterSQLstatementsterminatedwitha";" sqlite>.tables sqlite> 向上面这样,我们就在终端中创建了一个test.db数据库,并且通过 .tables命令查询数据库中的表,结果没有任何返回,因为数据库本 来就是空的嘛。 下面我们创建一个Student表,其中包含Id、Name、Age等字段. sqlite>CREATETABLEStudents(Idinteger,Nametext,age integer); sqlite>.tables Students sqlite>.schemaStudents CREATETABLEStudents(Idinteger,ageinteger); 向上面这样,一个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>.schemaTeachers CREATETABLE"Teachers"(Idinteger,ageinteger); sqlite>ALTERTABLETeachersADDCOLUMNSextext; sqlite>.schemaTeachers CREATETABLE"Teachers"(Idinteger,ageinteger,Sex text); 五、删除表DROPTABLE 删除一个表很简单,只要给出表名即可 删除表-DROPTABLE表名 下面,我们将test.db中的Teachers表删除 sqlite>.tables Teachers sqlite>DROPTABLETeachers; sqlite>.tables 删除Teachers表后再运行.tables命令,发现数据库已经空了。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |