是派小星呀 2022-10-08 16:14 采纳率: 63.6%
浏览 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日
  • 展开全部