Mysql修改、添加、刪除字段

1.添加字段

1.在末尾添加字段

(1)語法

ALTER TABLE <表名> ADD <字段名> <數據類型> [約束條件];

語法格式的說明:

  • <表名> 爲數據表的名字;
  • <字段名> 爲所要添加的字段的名字;
  • <數據類型> 爲所要添加的字段能存儲數據的數據類型;
  • [約束條件] 是可選的,用來對添加的字段進行約束。

這種語法格式默認在表的最後位置(最後一列的後面)添加新字段。

(2)示例

在user表末尾添加字段phone:

ALTER TABLE `user` ADD `phone` VARCHAR(11) DEFAULT NULL COMMENT '電話號碼';

2.在開頭添加字段

(1)語法

ALTER TABLE <表名> ADD <字段名> <數據類型> [約束條件] FIRST;

FIRST 關鍵字一般放在語句的末尾。

(2)示例

在user表開頭添加字段user_id:

ALTER TABLE `user` ADD `user_id` VARCHAR(32) NOT NULL COMMENT '用戶主鍵' FIRST;

3.在中間位置添加字段

(1)語法

ALTER TABLE <表名> ADD <字段名> <數據類型> [約束條件] AFTER <已經存在的字段名>;

AFTER 的作用是將新字段添加到某個已有字段後面。
注意:只能在某個已有字段的後面添加新字段,不能在它的前面添加新字段。

(2)示例

在user表的user_id字段後添加username字段:

ALTER TABLE `user` ADD `username` VARCHAR(30) DEFAULT NULL COMMENT '用戶名' AFTER `user_id`;

2.修改字段

1.修改字段屬性

(1)語法

ALTER TABLE <表名> MODIFY <字段名> <數據類型> [約束條件];

(2)示例

a)將email字段VARCHAR(50)修改成VARCHAR(200)

ALTER TABLE `user` MODIFY `email` VARCHAR(200) NOT NULL DEFAULT '[email protected]';

注意:修改時如果不帶完整性約束條件,原有的約束條件將丟失,如果想保留修改時就得帶上完整性約束條件

b)將email移到phone後面

ALTER TABLE `user` MODIFY `email` VARCHAR(50) AFTER `phone`;

c)將email放到第一個,保留原完整性約束條件

ALTER TABLE `user` MODIFY `email` VARCHAR(50) NOT NULL DEFAULT '[email protected]' FIRST;

d)將username字段修改成大小寫敏感,即查詢時區分大小寫

ALTER TABLE `user` MODIFY `username` VARCHAR(30) BINARY CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL COMMENT '用戶名';

2.修改字段名稱和屬性

(1)語法

ALTER TABLE <表名> CHANGE <原字段名> <新字段名> <數據類型> [約束條件];

(2)示例

將username字段修改成user_name

ALTER TABLE `user` CHANGE `username` `user_name` VARCHAR(30) DEFAULT NULL COMMENT '用戶名';

3.添加刪除默認值

(1)語法

-- 添加默認值
ALTER TABLE <表名> ALTER <字段名> SET DEFAULT <默認值>;

-- 刪除默認值
ALTER TABLE <表名> ALTER <字段名> DROP DEFAULT;

(2)示例

a)給sex添加默認值

ALTER TABLE `user` ALTER `sex` SET DEFAULT '男';

b)刪除sex的默認值

ALTER TABLE `user` ALTER `sex` DROP DEFAULT;

4.添加刪除主鍵

(1)語法

-- 添加主鍵
ALTER TABLE <表名> ADD [CONSTRAINT <約束名>] PRIMARY KEY (<字段名稱,...>);

-- 刪除主鍵
ALTER TABLE <表名> DROP PRIMARY KEY;

(2)示例

a)添加主鍵

ALTER TABLE `user` ADD PRIMARY KEY(`user_id`);

b)添加複合主鍵

ALTER TABLE `user_role` ADD PRIMARY KEY(`user_id`,`role_id`);

c)刪除主鍵

ALTER TABLE `user` DROP PRIMARY KEY;

d)刪除帶自增長屬性的主鍵

-- 先用MODIFY刪除自增長屬性,注意MODIFY不能去掉主鍵屬性
ALTER TABLE test MODIFY id INT UNSIGNED;
-- 再來刪除主鍵
ALTER TABLE test DROP PRIMARY KEY;

5.添加刪除唯一索引

(1)語法

-- 添加唯一性約束
ALTER TABLE <表名> ADD [CONSTANT <約束名>] UNIQUE [INDEX | KEY] [索引名稱](<字段名稱,...>)

-- 刪除唯一性約束
ALTER TABLE <表名> DROP [INDEX | KEY] [索引名稱];

(2)示例

a)爲username添加唯一性約束,如果沒有指定索引名稱,系統會以字段名建立索引

ALTER TABLE `user` ADD UNIQUE(`username`);

b)爲username添加唯一性約束,並指定索引名稱

ALTER TABLE `user` ADD UNIQUE KEY uni_username(`username`);

c)查看索引

SHOW CREATE TABLE `user`;

d)添加聯合unique

ALTER TABLE `user` ADD UNIQUE INDEX uni_nickname_username(`nickname`, `username`);

e)刪除索引

ALTER TABLE `user` DROP INDEX username;
ALTER TABLE `user` DROP KEY uni_username;
ALTER TABLE `user` DROP INDEX uni_nickname_username;

6.修改表的存儲引擎

(1)語法

ALTER TABLE <表名> ENGINE=<存儲引擎名稱>

(2)示例

ALTER TABLE `user` ENGINE=MyISAM;
ALTER TABLE `user` ENGINE=INNODB;

7.修改自增長值

(1)語法

ALTER TABLE <表名> AUTO_INCREMENT=[值];

(2)示例

ALTER TABLE `user` AUTO_INCREMENT=100;
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章