Mysql添加联合唯一索引及相同数据插入报错问题

吾爱主题 阅读:146 2022-11-20 17:41:00 评论:0

添加联合唯一索引及相同数据插入报错

1.添加联合索引

?
1 alter table "表名" add unique index (`字段1`,`字段2`)

2.此时如果在插入相同的数据会报错

可以使用 no duplicate key update 解决相同数据不存储,不会报错

?
1 2 insert into "表名" (` name `,`age`,` time `) values ( 'zhangsan' '18' '2001:10:10' ) on duplicate key update ` name `= values (` name `),`age`= values (`age`)

加了唯一索引,但数据还是有重复的,原来如此

今天刚创建了一个表,为订单号创建了唯一索引。

在测试同学测试的过程中,看了一下数据,竟然有重复订单号?

怎么想都想不明白,问了另一个大牛,他告诉我:

因为分库分表了。唯一键只能保证一个库中不重复,而不同库,无法限制。

我分库用的是平台ID,分表用的是订单号,我看了一下那两条数据,果然,平台ID不一样,那么他们有可能不在一个库里。

大牛说:你用同一个平台ID insert一下,我试了一下,果然插入不进去。

我就说嘛,数据库层是最底层的限制了,如果再限制不住,那还有什么可靠性可言呢?

嗯,大牛就是大牛。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/weixin_37460672/article/details/90258521

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容