Home >Database >Mysql Tutorial >MySql之ALTER命令用法详细解读_MySQL

MySql之ALTER命令用法详细解读_MySQL

WBOY
WBOYOriginal
2016-06-01 12:59:551086browse

本文详细解读了MySql语法中Alter命令的用法,这是一个用法比较多的语法,而且功能还是很强大的。

USE learning;(自己要提前建好)
CREATE TABLE student(id INT NOT NULL,
name CHAR(10) NOT NULL,
class INT NOT NULL,
age INT
);
来看看新建好的表
\

一、删除,添加或修改表字段

删除表字段


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

ALTER TABLE student  DROP age;
来看看结果:
\

 

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

添加表字段

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

 

ALTER TABLE student  ADD age INT NOT NULL;
执行以上命令后,i 字段会自动添加到数据表字段的末尾。

 

SHOW COLUMNS FROM student来看表结构

\
如果你需要指定新增字段的位置,可以使用MySQL提供的关键字 FIRST (设定位第一列), AFTER 字段名(设定位于某个字段之后)。
尝试以下 ALTER TABLE 语句, 在执行成功后,使用 SHOW COLUMNS 查看表结构的变化:

ALTER TABLE student  ADD sex CHAR(2) FIRST;

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

 

\

修改表字段

修改字段类型及名称
如果需要修改字段类型及名称, 你可以在ALTER命令中使用 MODIFY 或 CHANGE 子句 。
例如,把字段 name 的类型从 CHAR(10) 改为 CHAR(100),可以执行以下命令:
 

ALTER TABLE student  MODIFY age CHAR(100);
\

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

 

\

ALTER TABLE 对 Null 值和默认值的影响
当你修改字段时,你可以指定是否包含只或者是否设置默认值。
以下实例,指定字段sex为 NOT NULL 且默认值为男 。

ALTER TABLE sutdent  MODIFY sex  CHAR(2)  NOT NULL DEFAULT '男';
\
如果你不设置默认值,MySQL会自动设置该字段默认为 NULL。
你也可以使用 ALTER 命令及 DROP子句来删除字段的默认值,如下实例:
ALTER TABLE student ALTER sex DROP DEFAULT;
 SHOW COLUMNS FROM student;

 

\

修改数据表类型,可以使用 ALTER 命令及 TYPE 子句来完成。尝试以下实例,我们将表 student的类型修改为 MYISAM :
注意:查看数据表类型可以使用 SHOW CREATE TABLE 语句。

ALTER TABLE student ENGINE = MYISAM
SHOW CREATE TABLE student;
\

 

 

二、修改表名

如果需要修改数据表的名称,可以在 ALTER TABLE 语句中使用 RENAME 子句来实现。
尝试以下实例将数据表 student 重命名为 student_1:

mysql> ALTER TABLE student RENAME TO student_1;

\

三、主键和索引修改

删除表中主键

 

 

ALTER TABLE student  DROP PRIMARY KEY;

 

\

添加主键

 

 

ALTER TABLE student   ADD CONSTRAINT PK_STUDENT  PRIMARY KEY (id,class);

 

\

添加索引

 

ALTER TABLE student ADD INDEX index_name (name);

 

查看索引

 

SHOW INDEX FROM student;

 

\

添加唯一限制条件索引

 

ALTER TABLE student  ADD UNIQUE emp_name(age);

 

\

删除索引

ALTER TABLE student DROP INDEX index_name;

\

 

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn