美文网首页
MySQL之创建表格,数据的插入,更新与删除

MySQL之创建表格,数据的插入,更新与删除

作者: wenmingxing | 来源:发表于2018-06-06 21:22 被阅读44次

本文主要说明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 创建表格例题

牛客网SQL_CREATE例题1

牛客网SQL_CREATE例题2

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例题

牛客网SQL_INSERT例题1

牛客网SQL_INSERT例题2

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、例题

牛客网SQL_增加列_例题1

【参考】
[1] 《MySQL必知必会》

相关文章

网友评论

      本文标题:MySQL之创建表格,数据的插入,更新与删除

      本文链接:https://www.haomeiwen.com/subject/hpbbsftx.html