本文主要说明MySQL中表格的创建(CREATE),数据的插入方法(INSERT),以及更新(UPDATE)与删除(DELETE)数据的方法。

I、创建表格

1.1 表格创建基础

1、利用CREATE TABLE创建表,需要给出如下信息:

· 新表的名字,在关键字CREATE TABLE之后给出;

· 表列的名字和定义,用逗号分隔。

2、CREATE TABLE实例

# CREATE TABLE

> CREATE TABLE test

( cust_id int NOT NULL AUTO_INCREMENT,

cust_name char(50) NOT NULL,

PRIMARY KEY (cust_id)

) ENGINE = InnoDB;

表名紧跟在CREATE TABLE关键字后面,实际的表定义(所有列)括在圆括号之中。各列之间用逗号分隔,其顺序分别为列名,列的数据类型,以及NULL/NOT NULL,表的主键由PRIMARY KEY指定,最后的ENGINE指明所用的数据库引擎。

1.2 使用NULL值

允许NULL值的列也允许在插入行时不给出该列的值。不允许NULL值的列不接受该列没有值的行。

1.3 主键

主键值必须唯一。即,表中每个行必须具有唯一的主键值。如果主键使用单个列,则它的值必须唯一。如果使用多个列,则这些列的组合值必须唯一。

此外,主键值只能使用NOT NULL的列。允许NULL值的列不能作为唯一标识。

1.4 AUTO_INCREMENT

AUTO_INCREMENT告诉MySQL,本列每当增加一行时自动增量。每次执行一个INSERT操作时,MySQL自动对该列增量,为该列赋予下一个可用的值。这样给每个行分配一个唯一的cust_id,从而可以用作主键值。

1.5 指定默认值

默认值用CREATE TABLE语句的列定义中的DEFAULT关键字指定,如:

# DEFAULT

...

quantity int NOT NULL DEFAULT 1,

...

1.6 引擎类型

MySQL具有多种引擎。各自具有不同的功能和特性:

1、InnoDB是一个可靠的事务处理引擎,它不支持全文本搜索;

2、MEMORY在功能上等同于MyISAM,但由于数据存储在内存中,所以速度很快(适合做临时表);

3、MyISAM是一个性能极高的引擎,它支持全文本搜索,但不支持事务处理。

1.7 创建表格例题

II、插入数据

INSERT用来插入行到数据库表。插入可选用如下几种方式:

1、插入完整的行;

2、插入行的一部分;

3、插入多行;

4、插入某些查询的结果;

2.1 插入完整的行

我们通过一个例子来按如何插入一个完整的行:

# INSERT

> INSERT INTO test

VALUES (

1, "LiGang"

);

在使用INSERT对表进行插入的时候,每个列必须给定值,如果某个列没有值,则需要以NULL代替。

2.2 插入多行

以逗号分隔VALUES可以完成多行的批量插入:

# INSERT INTO VALUES

> INSERT INTO test

VALUES(2, "ZhangHong"), (3,"XiaoHong"), (4, "XiaoGang");

2.3 插入检索出的数据

MySQL可以直接将SELECT的数据INSERT到表中:

# INSERT INTO SELECT

> INSERT INTO test

SELECT cust_id, cust_name FROM other_test;

2.4 INSERT例题

III、更新与删除

3.1 更新数据

1、使用UPDATE对表中数据进行更新:

· 更新表中特定行;

· 更新表中所有行;

2、UPDATE主要有3个部分组成:

· 要更新的表名;

· 列名和它们的新值;

· 确定要更新行的过滤条件;

# UPDATE SET WHERE

> UPDATE test

SET cust_name = "Success"

WHERE cust_id 4;

3.2、删除数据

为了从表中删除数据使用DELEST语句:

· 从表中删除指定的行;

· 从表中删除所有行;

# DELETE FROM WHERE

> DELETE FROM test

WHERE cust_id = 5;

3.3 关于UPDATE 与 DELETE

使用这两条语句一定要注意WHERE条件的限定,否则很容易误操作为表的所有行。

IV、新增列与删除列

1、使用ALTER TABLE ...ADD...语句对表进行新增列的操作:

# ALTER TABLE ...ADD...

> ALTER TABLE test salary int NOT NULL DEFAULT100000

2、使用ALTER TABLE ... DROP...可以对列进行删除。

3、例题

【参考】

[1] 《MySQL必知必会》