是派小星呀 2022-10-08 16:14 采纳率: 65.1%
浏览 155
已结题

pg数据库序列值问题

现在我有个user_test表,里面有个test_id字段,有个唯一字段user_id,现在想将test_id为0的记录置为一个序列值,假如我这个表记录有好几百万条,但我每次只想置1w条,有什么好的办法吗?执行的sql最好效率要高能走索引,因为数据量比较大


UPDATE user_test set test_id = nextval('user_test_id_seq') where test_id =0;

现在想实现的功能 :UPDATE user_test set test_id = nextval('user_test_id_seq') where test_id =0 limit 10000; 此段sql会报错
  • 写回答

4条回答 默认 最新

  • 游一游走一走 2022-10-08 16:24
    关注
    UPDATE user_test SET test_id= nextval('user_test_id_seq')
    WHERE user_id IN (
        SELECT user_id FROM (
            SELECT user_id FROM user_test
            where test_id =0 
            LIMIT 10000
        ) subquery
    );
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 10月21日
  • 已采纳回答 10月13日
  • 修改了问题 10月8日
  • 修改了问题 10月8日
  • 展开全部

悬赏问题

  • ¥20 关于php录入完成后,批量更新数据库
  • ¥15 请教往复密封润滑问题
  • ¥15 cocos creator发布ios包
  • ¥15 comsol压电材料数据
  • ¥35 用python实现除法算法中goldschmidt算法
  • ¥15 汇编代码转换成C代码
  • ¥15 除法算法中的归一化具体是怎么变的?
  • ¥20 集成电路的逻辑电路和晶体管简化图
  • ¥15 下载windows builder后的问题
  • ¥15 端口连接数为什么会有限制