您现在的位置是:网站首页> 编程资料编程资料
Mysql添加联合唯一索引及相同数据插入报错问题_Mysql_
2023-05-26
355人已围观
简介 Mysql添加联合唯一索引及相同数据插入报错问题_Mysql_
添加联合唯一索引及相同数据插入报错
1.添加联合索引
alter table "表名" add unique index(`字段1`,`字段2`)
2.此时如果在插入相同的数据会报错
可以使用 no duplicate key update 解决相同数据不存储,不会报错
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一下,我试了一下,果然插入不进去。
我就说嘛,数据库层是最底层的限制了,如果再限制不住,那还有什么可靠性可言呢?
嗯,大牛就是大牛。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
相关内容
- Mysql optimize table 时报错:Temporary file write fail的解决_Mysql_
- mysql error 1071: 创建唯一索引时字段长度限制的问题_Mysql_
- MySQL8.0 索引优化invisible index详情_Mysql_
- MySQL创建唯一索引时报错Duplicate entry * for key问题_Mysql_
- Mysql数据库 ALTER 操作详解_Mysql_
- MySQL数据库表的合并与分区实现介绍_Mysql_
- sql语句 update字段null不能用is null问题_Mysql_
- 详解MySQL中数据类型和字段类型_Mysql_
- 关于mysql left join 查询慢时间长的踩坑总结_Mysql_
- 听说mysql中的join很慢?是你用的姿势不对吧_Mysql_
