V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Kinnice
V2EX  ›  PostgreSQL

一个 PG 的奇怪现象

  •  
  •   Kinnice · 2023-03-06 16:36:29 +08:00 · 1761 次点击
    这是一个创建于 627 天前的主题,其中的信息可能已经有所发展或是发生改变。

    在某业务表中对 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 ,第一次约束错误,第二次约束错误,第三次约束错误 ......

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

    第 1 条附言  ·  2023-03-07 10:26:32 +08:00
    感谢 @pubby ,查实为 glibc 的问题。
    5 条回复    2023-03-07 10:25:34 +08:00
    dbskcnc
        1
    dbskcnc  
       2023-03-06 21:28:13 +08:00
    版本? 切换最新的 patch 版试过没?
    Kinnice
        2
    Kinnice  
    OP
       2023-03-06 22:42:47 +08:00 via Android
    @dbskcnc 13.10 ,目前不确定什么情况会无视约束把数据写进去了。
    CoderLife
        3
    CoderLife  
       2023-03-06 23:17:20 +08:00
    遇到过类似的问题, 没有复现, 也没有找到原因
    pubby
        4
    pubby  
       2023-03-07 00:28:36 +08:00 via iPhone   ❤️ 1
    https://wiki.postgresql.org/wiki/Locale_data_changes

    改过 locale 或者升级过 glibc ?
    Kinnice
        5
    Kinnice  
    OP
       2023-03-07 10:25:34 +08:00
    感谢,确实是 glibc 的问题 @pubby
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2165 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 00:48 · PVG 08:48 · LAX 16:48 · JFK 19:48
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.