文章详情页
mysql UNIQUE的条件
浏览:193日期:2022-06-18 16:22:29
问题描述
ALTER TABLE `table` ADD `unionid` VARCHAR( 255 ) NOT NULL
然后设置唯一索引
ALTER TABLE `table` ADD UNIQUE (`unionid`)
提示
1062 - Duplicate entry ’’ for key ’unionid’请问这是为什么呢?
问题解答
回答1:第一句SQL:你给table表增加了unionid列,并且是非空字符串,所以初始值是空字符串’’;
第二句SQL:你给table表的unionid列建立唯一约束,但唯一约束的前提是unionid列的值不重复,然而unionid列的所有值都是空字符串’’,所以会报Duplicate entry ’’ for key ’unionid’。
解决方法:先把unionid的值修正为不重复后再给该列添加唯一约束。
回答2:直接进数据库操作啊,你添加索引就会有命令提示,这样不就知道哪里错了
相关文章:
1. dockerfile - 为什么docker容器启动不了?2. 为什么我ping不通我的docker容器呢???3. debian - docker依赖的aufs-tools源码哪里可以找到啊?4. angular.js - angular内容过长展开收起效果5. angular.js使用$resource服务把数据存入mongodb的问题。6. docker - 如何修改运行中容器的配置7. javascript - 关于火狐浏览器 XML 解析错误:格式不佳的问题8. mac里的docker如何命令行开启呢?9. javascript - h5上的手机号默认没有识别10. java - xml 传输数据如何处理更好
排行榜

网公网安备