MySQL修改已有表的结构、更改主键

MySQL修改已有表的结构、更改主键

因为业务需要,我要对已有的表做两种修改:①添加新的字段;②更改主键。

一、添加新的字段

ALTER TABLE 表名 ADD COLUMN 待增加的列名 待增加的列的数据类型 待增加的列的其他属性;

如:

ALTER TABLE user ADD COLUMN uuid varchar(20) NOT NULL;
ALTER TABLE user ADD COLUMN openid varchar(32);

二、删除已有字段

ALTER TABLE 表名 DROP COLUMN 待删除的列名;

如:

ALTER TABLE user DROP COLUMN uuid;

三、更改主键

1、去除旧主键(保留该字段)

ALTER TABLE 表名 DROP PRIMARY KEY;

如:

ALTER TABLE user DROP PRIMARY KEY;

2、设置新主键

ALTER TABLE 表名 ADD PRIMARY KEY(要设置为主键的列名);

如:

ALTER TABLE user ADD PRIMARY KEY(uuid);
设置新主键过程遇到的报错

这种做法对于一个还没有数据的表来说可以成功,但是对于已有数据的表而言,会提示错误:ERROR 1062 (23000): Duplicate entry '' for key 'PRIMARY'。原因是当前这个字段在所有的数据中的值都为‘’(一个空的字符串),即所有数据中这个字段的值是相同的,但设置这个字段为主键时要求这个字段的值不能重复。

解决方法一:为表中每条数据的这个字段设置不同的值(如果数据不多,这个步骤可以手动完成),然后再设置这个字段为主键。

解决方法二:保存这个表的数据信息(转储成sql文件),然后删除这个表,按照新的结构重新创建表并导入数据。

补充:为字段设置值

UPDATE TABLE 表名 SET 待修改的字段=设置的值;

如:

UPDATE TABLE user SET uuid=1;

参考

MySQL修改表结构

MySQL如何修改主键

  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值