將字段age的位置修改到字段class的后面 mysql> alter table db2.t1 modify age tinyint unsigned default 19 after class; //除了對字段age的位置進行了修改,其余不修改的地方如:類型(寬度)、約束條件進行原樣抄寫
mysql> desc db2.t1;
MySQL表結構實例分析
將字段name的類型變為varchar(15) mysql> alter table db2.t1 modify name varchar(15) not null default ""; mysql> desc db2.t1; MySQL表結構實例分析
修改字段名 基本用法 —— 也可以用來修改字段類型
mysql> alter table 庫名.表名 change 源字段名 新字段名 類型(寬度) 約束條件;
注:也可以用來修改類型和約束條件,只需要寫上新的類型和新的約束條件即可
mysql> desc db2.t1;
將字段名email修改為mail mysql> alter table db2.t1 change email mail varchar(50);
mysql> desc db2.t1;
將字段名mail修改為email,并修改約束條件 mysql> alter table db2.t1 change mail email varchar(50) not null default "njw@163.com"; //出現錯誤,因為源數據中,mail字段中的值為NULL,如果將約束條件修改為not null,那么就與源數據發生沖突,所以修改失敗 ERROR 1138 (22004): Invalid use of NULL value mysql> alter table db2.t1 change mail email varchar(50) default "njw@163.com"; mysql> desc db2.t1;
刪除字段 基本用法 mysql> alter table 庫名.表名 drop 字段名;
mysql> alter table db2.t1 drop email; //刪除庫db2中表t1的字段email mysql> desc db2.t1; //沒有字段email,已被刪除