一个 PG 的奇怪现象

2023-03-06 16:36:29 +08:00
 Kinnice

在某业务表中对 a,b,c,d 四个字段做了唯一性约束,如下

CONSTRAINT "hello_uinque" UNIQUE ("a", "b", "c", "d"),

但是经过一段时间的运行,出现了如下数据

id a b c d
1 z z z z
2 z z z z

即违反了唯一性约束,(在 Reindex 的时候发现的),其中 abcd 字段都不存在 null

做了一些尝试:

  1. 手动插入,确实显示受约束影响无法插入
  2. 手动重建约束 ==> 失败显示有重复数据
  3. 对数据进行 update

UPDATE 'hello' set a="z",b="z",c="z",d="z" where id=1

执行上述 sql ,第一次成功,第二次会报约束错误,第三次成功......循环往复

UPDATE 'hello' set a="z",b="z",c="z",d="z" where id=2

执行上述 sql ,第一次约束错误,第二次约束错误,第三次约束错误 ......

已经不知该如何排查了,求教

1602 次点击
所在节点    PostgreSQL
5 条回复
dbskcnc
2023-03-06 21:28:13 +08:00
版本? 切换最新的 patch 版试过没?
Kinnice
2023-03-06 22:42:47 +08:00
@dbskcnc 13.10 ,目前不确定什么情况会无视约束把数据写进去了。
CoderLife
2023-03-06 23:17:20 +08:00
遇到过类似的问题, 没有复现, 也没有找到原因
pubby
2023-03-07 00:28:36 +08:00
https://wiki.postgresql.org/wiki/Locale_data_changes

改过 locale 或者升级过 glibc ?
Kinnice
2023-03-07 10:25:34 +08:00
感谢,确实是 glibc 的问题 @pubby

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/921641

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX