littlemoney
V2EX  ›  问与答

如何避免 pg 插入数据报 id 已存在的问题

  •  1
     
  •   littlemoney · Sep 20, 2020 · 978 views
    This topic created in 2082 days ago, the information mentioned may be changed or developed.
    id 采用自增序列,如果这时候 sequence 才自增到 100,你手动插入一条数据 id 是 200 [此时的 sequence 还是 100 ] ,如何避免在程序自动插入数据的时候,sequence 到 200 的时候,插入不会报错,能否直接跳过 200,到 201 ?

    mysql 是没有这个问题的,不知道 pg 需要做什么配置才能避免这个问题呢
    2 replies    2020-09-22 10:08:49 +08:00
    FlyingShark
        1
    FlyingShark  
       Sep 21, 2020
    触发器,insert 之前获取自定义序列
    Aksura
        2
    Aksura  
       Sep 22, 2020
    sequence 列本来就是为了让数据库自增才用的,如果插入的时候对这个列插入值,那就要 nextval 取值、setval 重置。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1107 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 44ms · UTC 18:07 · PVG 02:07 · LAX 11:07 · JFK 14:07
    ♥ Do have faith in what you're doing.