MySql索引失效-联合唯一索引含null值

在尝试使用MySQL的联合唯一索引来避免数据重复时,发现索引在包含NULL值的情况下失效。问题出现在当索引列含有NULL时,相同的非NULL值可以重复插入。解决方案包括避免使用可能为NULL的字段作为索引,或用特殊值替换NULL,例如将address字段默认值设为空字符。
摘要由CSDN通过智能技术生成

一.背景

今天在测试过程中发现有数据重复的现象,想设计一个唯一索引达到幂等的效果,但是发现设置了唯一索引以后还是可以插入相同的数据,经过排查,发现联合唯一索引中含有null值会导致索引失效。

二.问题复现

现在我们来复现一下这个场景。

2.1 首先创建一个 user 表,指定 user_name + address 为联合唯一索引

CREATE TABLE `t_user` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
  `user_name` varchar(256) NOT NULL COMMENT '用户名',
  `sex&
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值