本文主要说明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必知必会》