Mysql修改、添加、删除字段

1|01.添加字段

1|11.在末尾添加字段

(1)语法

ALTER TABLE <表名> ADD <字段名> <数据类型> [约束条件];

语法格式的说明:

  • <表名> 为数据表的名字;
  • <字段名> 为所要添加的字段的名字;
  • <数据类型> 为所要添加的字段能存储数据的数据类型;
  • [约束条件] 是可选的,用来对添加的字段进行约束。

这种语法格式默认在表的最后位置(最后一列的后面)添加新字段。

(2)示例

在user表末尾添加字段phone:

ALTER TABLE `user` ADD `phone` VARCHAR(11) DEFAULT NULL COMMENT '电话号码';

1|22.在开头添加字段

(1)语法

ALTER TABLE <表名> ADD <字段名> <数据类型> [约束条件] FIRST;

FIRST 关键字一般放在语句的末尾。

(2)示例

在user表开头添加字段user_id:

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

1|33.在中间位置添加字段

(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|02.修改字段

2|11.修改字段属性

(1)语法

ALTER TABLE <表名> MODIFY <字段名> <数据类型> [约束条件];

(2)示例

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

ALTER TABLE `user` MODIFY `email` VARCHAR(200) NOT NULL DEFAULT 'email@163.com';

注意:修改时如果不带完整性约束条件,原有的约束条件将丢失,如果想保留修改时就得带上完整性约束条件

b)将email移到phone后面

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

c)将email放到第一个,保留原完整性约束条件

ALTER TABLE `user` MODIFY `email` VARCHAR(50) NOT NULL DEFAULT 'test@163.com' FIRST;

d)将username字段修改成大小写敏感,即查询时区分大小写

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

2|22.修改字段名称和属性

(1)语法

ALTER TABLE <表名> CHANGE <原字段名> <新字段名> <数据类型> [约束条件];

(2)示例

将username字段修改成user_name

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

2|33.添加删除默认值

(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;

2|44.添加删除主键

(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;

2|55.添加删除唯一索引

(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;

2|66.修改表的存储引擎

(1)语法

ALTER TABLE <表名> ENGINE=<存储引擎名称>

(2)示例

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

2|77.修改自增长值

(1)语法

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

(2)示例

ALTER TABLE `user` AUTO_INCREMENT=100;

__EOF__

本文作者wugongzi
本文链接https://www.cnblogs.com/wugongzi/p/14340550.html
关于博主:我是说故事的五公子,欢迎扫描左边二维码关注
版权声明:沪漂一员,互联网架构方向,如有问题探讨可以直接私信我,亦可下方留言。
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   五公子说  阅读(582)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
点击右上角即可分享
微信分享提示