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

 更新时间:2013年12月17日 23:36:36   作者:  
今天这一篇只涉及到表的相关内容,视图、触发器等到后面再讲

一、数据库定义语言 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 命令,发现数据库已经空了。

六、后续内容

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

您可能感兴趣的文章:

相关文章

  • SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

    SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

    本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用BLOB存储,辅以压缩和故障安全机制,适合资源受限的嵌入式系统,对SQLite3存储文件相关知识感兴趣的朋友一起看看吧
    2025-06-06
  • SQLite教程(六):表达式详解

    SQLite教程(六):表达式详解

    这篇文章主要介绍了SQLite教程(六):表达式详解,本文讲解了常用表达式、条件表达式、转换表达式等内容,需要的朋友可以参考下
    2015-05-05
  • sqlite中文乱码问题原因分析及解决

    sqlite中文乱码问题原因分析及解决

    打开数据库,插入,查询数据库等,如果操作接口输入参数包含中文字符,会导致操作异常,这是由于sqlite数据库使用的是UTF-8编码方式
    2013-04-04
  • SQLite教程(三):数据表和视图简介

    SQLite教程(三):数据表和视图简介

    这篇文章主要介绍了SQLite教程(三):数据表和视图简介,本文讲解了创建数据表、表的修改、表的删除、创建视图、删除视图等内容,需要的朋友可以参考下
    2015-05-05
  • SQLite数据库管理系统-我所认识的数据库引擎

    SQLite数据库管理系统-我所认识的数据库引擎

    SQLite是一款轻量级的、被设计用于嵌入式系统的关联式数据库管理系统,SQLite 是一个实现自我依赖、纯客户端、零配置且支持事务的数据库引擎
    2013-01-01
  • CentOS下更新SQLite版本

    CentOS下更新SQLite版本

    SQLite是一个软件库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。这篇文章主要介绍了CentOS下更新SQLite版本,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2021-12-12
  • SQLite中的WAL机制详细介绍

    SQLite中的WAL机制详细介绍

    这篇文章主要介绍了SQLite中的WAL机制详细介绍,本文讲解了什么是WAL、WAL如何工作、WAL的优点与缺点、WAL引入的兼容性问题、WAL引入的性能问题等内容,需要的朋友可以参考下
    2015-01-01
  • SQLite3 安装、基本操作使用示例

    SQLite3 安装、基本操作使用示例

    本文介绍了SQLite3的安装方法(含可选工具包和图形界面)及基本操作,包括数据库创建、表结构定义、数据增删改查和删除数据库文件的技巧,同时概述了其轻量、嵌入式、跨平台、ACID事务等核心特性,感兴趣的朋友跟随小编一起看看吧
    2025-06-06
  • SQLite 转换字符串为日期的示例代码

    SQLite 转换字符串为日期的示例代码

    在本文中,我们介绍了如何在SQLite数据库中进行字符串和日期的转换,我们学习了如何使用date函数将字符串转换为日期,以及如何使用strftime函数将日期转换为字符串,感兴趣的朋友跟随小编一起看看吧
    2024-08-08
  • Sqlite3基本语句及安装过程

    Sqlite3基本语句及安装过程

    SQLite3是轻量级嵌入式数据库,零配置无需服务器,数据存储于.db文件,支持基本SQL操作如创建表、查询、更新、删除,及where条件筛选,Ubuntu下可通过命令安装,常用指令包括.help、.tables等,本文给大家介绍Sqlite3基本语句,感兴趣的朋友一起看看吧
    2025-06-06

最新评论