MySQL ALTER命令

当我们需要修改数据表名或者修改数据表字段时,就需要使用到MySQL ALTER命令。让我们先创建一张表,表名为:testalter_tbl。

root@host# mysql -u root -p password;

Enter password:*******mysql> useOPENKETANG;

Database changed mysql> create tabletestalter_tbl   

-> (-> i INT,-> c CHAR(1)-> );

Query OK, 0 rows affected (0.05 sec)

mysql> SHOW COLUMNS FROM testalter_tbl;

+-------+---------+------+-----+---------+-------+

| Field | Type    | Null | Key | Default | Extra |

+-------+---------+------+-----+---------+-------+

| i    | int(11) | YES  |     | NULL   |       |

| c    | char(1) | YES  |     | NULL   |       |

+-------+---------+------+-----+---------+-------+

2 rows in set (0.00 sec)

 

删除,添加或修改表字段

如下命令使用了 ALTER 命令及 DROP 子句来删除以上创建表的 i 字段:

mysql> ALTER TABLE testalter_tbl  DROP i;

如果数据表中只剩余一个字段则无法使用DROP来删除字段。


MySQL 中使用 ADD 子句来想数据表中添加列,如下实例在表 testalter_tbl 中添加 i 字段,并定义数据类型:

mysql> ALTER TABLE testalter_tbl ADD iINT;

执行以上命令后,i 字段会自动添加到数据表字段的末尾。


mysql> SHOW COLUMNS FROM testalter_tbl;

+-------+---------+------+-----+---------+-------+

| Field | Type    | Null | Key | Default | Extra |

+-------+---------+------+-----+---------+-------+

| c    | char(1) | YES  |     | NULL   |       |

| i    | int(11) | YES  |     | NULL   |       |

+-------+---------+------+-----+---------+-------+

2 rows in set (0.00 sec)

如果你需要指定新增字段的位置,可以使用MySQL提供的关键字 FIRST (设定位第一列), AFTER 字段名(设定位于某个字段之后)。

尝试以下 ALTER TABLE 语句, 在执行成功后,使用 SHOW COLUMNS 查看表结构的变化:

ALTER TABLE testalter_tbl DROP i;

ALTER TABLE testalter_tbl ADD i INTFIRST;ALTER TABLE testalter_tbl DROP i;

ALTER TABLE testalter_tbl ADD i INT AFTERc;

FIRST 和 AFTER 关键字只占用于 ADD 子句,所以如果你想重置数据表字段的位置就需要先使用 DROP 删除字段然后使用 ADD 来添加字段并设置位置。

 

修改字段类型及名称

如果需要修改字段类型及名称, 你可以在ALTER命令中使用 MODIFY 或 CHANGE 子句。

例如,把字段 c 的类型从 CHAR(1) 改为 CHAR(10),可以执行以下命令:

mysql> ALTER TABLE testalter_tbl MODIFYc CHAR(10);

使用 CHANGE 子句, 语法有很大的不同。在 CHANGE 关键字之后,紧跟着的是你要修改的字段名,然后指定新字段名及类型。尝试如下实例:

mysql> ALTER TABLE testalter_tbl CHANGEi j BIGINT;

<p如果你现在想把字段j="" 从="" bigint="" 修改为="" int,sql语句如下:<=""p="">

mysql> ALTER TABLE testalter_tbl CHANGEj j INT;

 

ALTER

TABLE 对 Null 值和默认值的影响

当你修改字段时,你可以指定是否包含只或者是否设置默认值。

以下实例,指定字段 j 为 NOT NULL 且默认值为100 。

mysql> ALTER TABLE testalter_tbl

-> MODIFY j BIGINT NOT NULL DEFAULT 100;

如果你不设置默认值,MySQL会自动设置该字段默认为 NULL。


修改字段默认值

你可以使用 ALTER 来修改字段的默认值,尝试以下实例:

mysql> ALTER TABLE testalter_tbl ALTER iSET DEFAULT 1000;

mysql> SHOW COLUMNS FROM testalter_tbl;

+-------+---------+------+-----+---------+-------+

| Field | Type    | Null | Key | Default | Extra |

+-------+---------+------+-----+---------+-------+

| c    | char(1) | YES  |     | NULL   |       |

| i    | int(11) | YES  |     | 1000   |       |

+-------+---------+------+-----+---------+-------+

2 rows in set (0.00 sec)


你也可以使用 ALTER 命令及 DROP子句来删除字段的默认值,如下实例:

mysql> ALTER TABLE testalter_tbl ALTER iDROP DEFAULT;

mysql> SHOW COLUMNS FROM testalter_tbl;

+-------+---------+------+-----+---------+-------+

| Field | Type    | Null | Key | Default | Extra |

+-------+---------+------+-----+---------+-------+

| c    | char(1) | YES  |     | NULL   |       |

| i    | int(11) | YES  |     | NULL   |       |

+-------+---------+------+-----+---------+-------+

2 rows in set (0.00 sec)Changing a TableType:


修改数据表类型,可以使用 ALTER 命令及 TYPE 子句来完成。尝试以下实例,我们将表 testalter_tbl 的类型修改为 MYISAM :

注意:查看数据表类型可以使用 SHOW TABLE STATUS 语句。

mysql> ALTER TABLE testalter_tbl ENGINE= MYISAM;;mysql> 

SHOW TABLE STATUS LIKE 'testalter_tbl'\G

*************************** 1. row****************

Name: testalter_tbl

Type: MyISAM

Row_format: Fixed

Rows: 0

Avg_row_length: 0

Data_length: 0

Max_data_length: 25769803775

Index_length: 1024

Data_free: 0

Auto_increment: NULL   

Create_time: 2007-06-03 08:04:36

Update_time: 2007-06-03 08:04:36

Check_time: NULL Create_options:

Comment:1 row in set (0.00 sec)


修改表名

如果需要修改数据表的名称,可以在 ALTER TABLE 语句中使用 RENAME 子句来实现。

尝试以下实例将数据表 testalter_tbl 重命名为 alter_tbl:

mysql> ALTER TABLE testalter_tbl RENAMETO alter_tbl;


更多MySQL课程:阿里云大学——开发者课堂

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 什么是数据库? 数据库是存储数据的集合的单独的应用程序。每个数据库具有一个或多个不同的API,用于创建,访问,管理...
    chen_000阅读 9,475评论 0 19
  • mysql中delete、truncate、drop的区别 1.delete和truncate仅删除表数据,dro...
    好一个坏小孩阅读 4,023评论 0 1
  • 一、数据库简介 1.数据库系统 1.1数据库 DataBase【DB】,指的是长期保存到计算机上的数据,按照一定顺...
    郑元吉阅读 3,741评论 0 6
  • 1、MySQL启动和关闭(安装及配置请参照百度经验,这里不再记录。MySQL默认端口号:3306;默认数据类型格式...
    强壮de西兰花阅读 3,954评论 0 1
  • 我是个南方人,但对北方麦质的饼类小吃很向往,记得我第一次吃煎饼馃子,是在学校门口,一个不起眼的小摊上,一块红色的招...
    叶伶阅读 7,204评论 44 60

友情链接更多精彩内容