为了账号安全,请及时绑定邮箱和手机立即绑定

Mysql-Alter命令-修改表结构

标签:
MySQL

一、新增列

  • 新增ID列

ALTER TABLE table_name ADD id bigint PRIMARY KEY AUTO_INCREMENT first;

first 表示设置该列为表的第一列

  • 新增普通列

ALTER TABLE table_name ADD col_name col_type after exists_col_name;

after 表示新增的列在已存在的某一列后面

二、修改列

  • 修改某一列

ALTER TABLE table_name MODIFY COLUMN col_name col_type;

三、创建索引

  • 创建主键

ALTER TABLE `table_name` ADD PRIMARY KEY (`col_name`);
  • 创建普通索引

ALTER TABLE `table` ADD INDEX `index_name` (`col_name`);

In MySQL, if you use ALTER TABLE tbl ADD INDEX (col) instead of ALTER TABLE tbl ADD INDEX col (col), then using ALTER TABLE tbl ADD INDEX (col) more than once will keep adding indices named col_2,col_3,... each time. Whereas using ALTER TABLE tbl ADD INDEX col (col) 2nd time, will give ERROR 1061 (42000): Duplicate key name 'col'.

  • 创建唯一索引

ALTER TABLE `table_name` ADD UNIQUE unique_index_name (`col_name`);
  • 创建联合索引

ALTER TABLE `table_name` ADD INDEX `index_name` (`col_01`, `col_02`);

注意:联合索引需遵循最左匹配原则。

  • 移除索引

DROP INDEX `index_name` ON `table_name`;

如果遇到无法删除索引的情况,比如DRDS一般就不能直接drop,需要使用alter table来操作,如下:

ALTER TABLE `table_name` DROP INDEX `index_name`;
  • 查询表索引

SHOW INDEX FROM `table_name`;
  • 修改AUTO_INCREMENT

ALTER TABLE table_name AUTO_INCREMENT = value;
  • 修改DRDS sequence

ALTER SEQUENCE <sequence_name> START WITH <numeric_value>



作者:泥称已被栈用
链接:https://www.jianshu.com/p/e3f09d2c9bab


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消