`
104zz
  • 浏览: 1507858 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类

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

 
阅读更多

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

六、后续内容

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


//=================================================================================================== 

分享到:
评论

相关推荐

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

    SQLite 入门教程二 SQLite 的创建、修改、删除表 SQLite 是一种轻量级的关系型数据库管理系统,本篇文章主要介绍 SQLite 中的表操作,包括创建、修改和删除表。 数据库定义语言(DDL) 在关系型数据库中,数据库...

    无涯教程(LearnFk)-SQLite教程完整离线版.pdf

    - DML(数据操作语言):用于操作数据库中数据的命令,如INSERT(创建记录)、UPDATE(修改记录)、DELETE(删除记录)。 - DQL(数据查询语言):用于查询数据库中数据的命令,如SELECT(从一个或多个表中检索记录...

    SQLite菜鸟教程

    5. **更新与删除数据**:UPDATE语句用于修改已有数据,DELETE FROM语句用于删除表中的记录。同时会讲解JOIN操作,用于合并多张表的数据。 6. **索引**:介绍创建、查看和删除索引的概念,以及如何利用索引来提升...

    SQLite入门与分析

    SQLite遵循SQL标准,支持常见的数据操作语言,如CREATE TABLE用于创建表,INSERT用于插入数据,SELECT用于查询数据,UPDATE用于更新数据,DELETE用于删除数据,以及ALTER TABLE用于修改表结构。此外,还支持JOIN操作...

    2014年辛星Python数据库Sqlite3教程

    SQLite支持标准的数据库操作,包括数据的增加、删除、修改和查询,并且还支持事务处理。SQLite支持多种编程语言,其中Python对它的支持尤其方便,Python 2.5版本起内置了sqlite3库,使得Python操作SQLite变得简单...

    sqlite数据库、可视化工具和入门操作

    1. **创建数据库**:使用`CREATE DATABASE`语句创建新的SQLite数据库,不过在SQLite中,通常只需创建一个空的SQLite3文件,数据库就会自动建立。 2. **连接数据库**:使用`sqlite3`命令行工具,或者像SqliteStudio...

    SQLite快速入门资料

    在“SQLite快速入门资料@www.java1234.com.pdf”这份文档中,你可能会学习到如何安装和配置SQLite,如何在Java项目中集成SQLite-JDBC驱动,以及如何编写SQL语句来创建表、插入数据、更新数据和删除数据。此外,还...

    SQLite 入门教程一 基本控制台(终端)命令

    SQLite 支持常见的数据库管理操作,如创建表、查询数据、更新和删除记录。例如,创建表的 SQL 语句如下: ```sql CREATE TABLE Cars( Id integer PRIMARY KEY, Name text, Cost integer ); ``` 插入数据: ```...

    sqlite3入门资料

    1. SQLite3的基本操作:包括数据库的创建、打开、关闭、查询、更新、插入和删除等基本SQL命令。初学者首先需要熟悉这些操作,这是使用SQLite3进行数据管理和操作的基础。 2. 常用的SQLite3常量定义:例如SQLITE_OK...

    IOS数据库SQLite入门代码及详细文章讲解

    2. **创建表**:通过执行SQL的`CREATE TABLE`语句创建数据表结构。 3. **插入数据**:使用`sqlite3_exec()`函数执行`INSERT INTO`语句插入数据。 4. **查询数据**:执行`SELECT`语句获取数据,通常需要编写回调函数...

    SQLITE学习资料入门

    7. ALTER TABLE:修改表结构,如添加、删除或修改列。 8. DROP TABLE/DATABASE:删除表或整个数据库。 五、事务处理 SQLite支持ACID(原子性、一致性、隔离性和持久性)事务,保证了数据操作的可靠性。BEGIN、...

    sqlite3使用入门.

    学习 SQLite3 时,建议结合官方文档(sqlite-doc-3070701.zip)和 SQL 入门教程,以便更深入地理解 SQL 语言和 SQLite3 的特性。SQLite3 支持大部分 SQL 标准,同时也有一些特有的功能,如动态列类型,这使得在 ...

    sqlite数据库

    这篇教程将带你深入了解SQLite数据库的入门知识,包括其基本概念、安装与配置、数据操作、事务处理、索引与视图、以及通过C接口进行编程测试。 一、SQLite基础 SQLite是一个关系型数据库管理系统,它遵循SQL标准,...

    Android平台sqlite快速入门

    `onUpgrade()`在升级数据库版本时调用,可以用于修改表结构。 4. **SQLiteDatabase方法**: - `getWritableDatabase()`:获取可读写的数据库实例。 - `getReadableDatabase()`:获取只读的数据库实例。 - `...

    Django1.5 官方入门教程第1部分中文版

    这就是Django1.5入门教程第一部分的主要内容,涵盖了从创建项目、定义模型、创建视图和模板到设置URL和管理站点的基础流程。通过实践这些步骤,你将掌握Django的基本用法,为构建更复杂的应用打下坚实的基础。

Global site tag (gtag.js) - Google Analytics