MySQL中因为unique key 非空唯一索引存在导致修改主键失败案例

研发在早期的设计中,由于设计方面的问题,导致在设计表结构的时候,有个表有非空唯一索引而没有主键

在InnoDB存储引擎中,如果没有主键的情况下,有非空唯一索引的话,非空唯一索引即为主键。

那么这就会有个问题存在

应用在更新表的时候,用了

update aaaa
    set xxx=xxx+(-1)
    where id=412  and xxx+(-1)>=0 

用了ID作为条件,修改,高事务并发下,可能会同时发生这种事务,由于id并没有任何索引,故此,表会被全锁,也就是全表。那么如何避免这个问题。我们线上的数据

暂时还不是很大,故此

drop index idx_aaa_unique on goods_cost;
alter table goods_cost add primary key(id);
alter table goods_cost add constraint idx_aaa_unique unique (`xx`,`bb`); 

如果直接插入主键,会报错。

转载于:https://www.cnblogs.com/olinux/p/5497213.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值