MySQL中ALTER ,CHANGE , MODIFY

MySQL中ALTER ,CHANGE , MODIFY,第1张

将表格修改为下面第二个表格形式。

用一条ALTER语句实现。

CHANGE:如果我们不只是修改单一列,而是用一条语句改变两个列,我们需要修改列的名称,同时更改他们的数据类型,这时就需要我们用到关键字CHANGE,可以在一条语句中放入多个CHANGE,在中间加上分隔的逗号即可。

比如原来的表两列,类型为VARCHAR(50),和VARCHAR(10),现在不止要更改列名,还要更改这两列的类型。

程序如下:

MODIFY:使用它可以只修改列的类型而不会干涉它的名称,假设要把proj_desc列的字符长度修改为VARCHAR(120)以容纳更多的说明文字,只要这么做就可以。

总结如下

(1)既更改列名也更改类型,用CHANGE

(2)只修改类型,用MODIFY,但这种方法比较慢,我们用另一种方法直接修改.frm文件,而不改动表本身。

modify能修改字段类型和约束,而change不能。

change用来字段重命名,不能修改字段类型和约束;

modify不用来字段重命名,只能修改字段类型和约束;

试验比较:

1、字段重命名:

1)change

mysql>alter table t1 change number id char(2)

Query OK, 0 rows affected (0.08 sec)

Records: 0 Duplicates: 0 Warnings: 0

2)modify

mysql>alter table t1 modify id num int(2)

ERROR 1064 (42000): You have an error in your SQL syntaxcheck the manual that corresponds to your MySQL server version for the right syntax to use near 'num int(2)' at line 1

mysql>

结论:能用change重命名,而modify不能。

2、修改字段类型和约束

1)modify

mysql>alter table t1 modify id int(2)

Query OK, 0 rows affected (0.06 sec)

Records: 0 Duplicates: 0 Warnings: 0

mysql>alter table t1 modify id int(2) not null

Query OK, 0 rows affected (0.08 sec)

Records: 0 Duplicates: 0 Warnings: 0

2)change

mysql>alter table t1 change id char(2)

ERROR 1064 (42000): You have an error in your SQL syntaxcheck the manual that corresponds to your MySQL server version for the right syntax to use near 'char(2)' at line 1

mysql>alter table t1 change id char(2) not null

ERROR 1064 (42000): You have an error in your SQL syntaxcheck the manual that corresponds to your MySQL server version for the right syntax to use near 'char(2) not null' at line 1

结论:modify能修改字段类型和约束,而change不能。

最终结论:change用来字段重命名,不能修改字段类型和约束;

modify不用来字段重命名,只能修改字段类型和约束;

区别:

1、CHANGE 对列进行重命名或更改列的类型,需给定旧的列名称和新的列名称、当前的类型MODIFY 可以改变列的类型,此时不需要重命名(不需给定新的列名称)

2、案例

以使用CHANGE old_col_namecolumn_definition子句对列进行重命名。重命名时,需给定旧的和新的列名称和列当前的类型。例如:要把一个INTEGER列的名称从a变更到b,需要如下 *** 作:

·mysql>ALTER TABLE t1 CHANGE a b INTEGER

如果想要更改列的类型而不是名称, CHANGE语法仍然要求旧的和新的列名称,即使旧的和新的列名称是一样的。例如:

mysql>ALTER TABLE t1 CHANGE b b BIGINT NOT NULL

也可以使用MODIFY来改变列的类型,此时不需要重命名:

mysql>ALTER TABLE t1 MODIFY b BIGINT NOT NULL

mysql alter 语句用法,添加、修改、删除字段等

//主键549830479

alter table tabelname add new_field_id int(5) unsigned default 0 not null auto_increment ,add primary key (new_field_id)

//增加一个新列549830479

alter table t2 add d timestamp

alter table infos add ex tinyint not null default '0'

//删除列549830479

alter table t2 drop column c

//重命名列549830479

alter table t1 change a b integer

//改变列的类型549830479

alter table t1 change b b bigint not null

alter table infos change list list tinyint not null default '0'

//重命名表549830479

alter table t1 rename t2

加索引549830479

mysql>alter table tablename change depno depno int(5) not null

mysql>alter table tablename add index 索引名 (字段名1[,字段名2 …])

mysql>alter table tablename add index emp_name (name)

加主关键字的索引549830479

mysql>alter table tablename add primary key(id)

加唯一限制条件的索引549830479

mysql>alter table tablename add unique emp_name2(cardnumber)

删除某个索引549830479

mysql>alter table tablename drop index emp_name

修改表:549830479

增加字段:549830479

mysql>ALTER TABLE table_name ADD field_name field_type

修改原字段名称及类型:549830479

mysql>ALTER TABLE table_name CHANGE old_field_name new_field_name field_type

删除字段:549830479

mysql>ALTER TABLE table_name DROP field_name

删除主键: alter table Employees drop primary key


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6168032.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-17
下一篇 2023-03-17

发表评论

登录后才能评论

评论列表(0条)

保存