MySQL命令随手记之alter

  • 修改表名

alter table 表名 rename 新表名; //修改table名

  • 添加、删除、修改字段

alter table 表名 add [column] 列名 数据类型;  //添加column

alter table 表名 drop [column] 列名;  //删除column

alter table 表名 modify [column] 列名 新数据类型;  //修改column的数据类型

alter table 表名 change [column] 列名 新列名 新数据类型;  //修改column名称及数据类型

REMAEK:

  • column 关键字是可选的(可以不写)
  • 添加、删除主键约束

alter table 表名 add constraint 约束名 primary key(列名 [,列名,...]) ;  //创建主键

alter table 表名 add primary key(列名 [,列名,...]) ;  //创建主键

alter table 表名 drop primary key;  //删除主键

REMARK:

  • 由于MySQL删除主键并不能通过  alter table 表名 drop constraint 约束名 来删除
  • 因此推测对于主键的约束可能会被忽略
  • 于是我加上约束创建了一个主键,然后  show create table 表名 ,主键创建相关代码如下
PRIMARY KEY (`Sno`)
  •  可见约束确实被忽略了(个人理解)
  • 添加、删除外键约束

alter table 表名 add constraint 约束名 foreign key(列名) references 表名(列名) ;  //添加外键  

alter table 表名 add foreign key(列名) references 表名(列名);  //添加外键

alter table 表名 drop foreign key 约束名;  //删除外键

REMARK:                   

  • 对于用第一种方法创建的外键 约束名 是自己设置的
  • 对于用第二种方法设置的外键,MySQL会自动生成约束
  • 可以通过  show create table 表名 来查看生成的约束名
  •  下面是我用第二种方法创建外键之后,使用  show create table 表名  得到的外键创建相关代码
 CONSTRAINT `Teacher_Course_ibfk_1` FOREIGN KEY (`Teacher_id`) REFERENCES `Teacher` (`Id`)
  • 可见如果不加约束直接创建 foreign key
  • MySQL仍然会按照类似的规则创建约束
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xxpr_ybgg

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值