postgresql 重置对应表序列最大值

当使用pg库备份并恢复时,序列的值很可能不会自动更新到最大ID。

原因是,insert语句如果默认写了id,就不会更新序列的值,需要自己拨一下序列的值...

简单来说如下命令就好了,两个your_table 换成你自己的真实表名。

sql 复制代码
SELECT setval('your_table_id_seq', (SELECT MAX(id) FROM your_table));

注:这里 _id_seq 你要看是否和自己的数据库一样,一般默认都用的这个。

然后上面虽然一个表搞定了,但我想对所有表都操作一次,那么使用如下脚本,可以在navicat等工具里直接新建查询,粘贴进去执行一下就好了(实测pg17一次解决)。

复制代码
DO $$
DECLARE
    tab_record RECORD;
    seq_name TEXT;
BEGIN
    FOR tab_record IN 
        SELECT table_name
        FROM information_schema.tables
        WHERE table_schema = 'public'
        AND table_type = 'BASE TABLE'
    LOOP
        -- 直接构建序列名
        seq_name := 'public.' || tab_record.table_name || '_id_seq';
        
        BEGIN
            -- 尝试重置序列
            EXECUTE format('SELECT setval(%L, (SELECT COALESCE(MAX(id), 1) FROM public.%I))', 
                      seq_name, tab_record.table_name);
                      
            RAISE NOTICE '表 % 的序列已更新', tab_record.table_name;
        EXCEPTION WHEN OTHERS THEN
            -- 忽略没有对应序列的表
            RAISE NOTICE '表 % 跳过: %', tab_record.table_name, SQLERRM;
        END;
    END LOOP;
END
$$;
相关推荐
望获linux3 分钟前
【Linux基础知识系列】第六十四篇 - 了解Linux的硬件架构
linux·运维·服务器·开发语言·数据库·操作系统·嵌入式软件
全栈小512 分钟前
【数据库】使用Sql Server将分组后指定字段的行数据转为一个字段显示,并且以逗号隔开每个值,收藏不迷路
数据库·sql server
JohnYan33 分钟前
工作笔记 - 一种业务信息汇报机制的设计和实现
数据库·后端·postgresql
sq8001 小时前
EFCore ORM 数据库数据表迁移
数据库·后端·orm
小徐不徐说1 小时前
深入理解 Qt 信号与槽机制的底层逻辑
数据库·c++·qt·面试
一只小小汤圆2 小时前
qt 心跳包
服务器·数据库·qt
巴里巴气2 小时前
MongoDB事务和隔离级别的原理
数据库·mongodb
什么半岛铁盒2 小时前
MySQL的常用数据类型详解
linux·数据库·mysql·adb
rannn_1112 小时前
【MySQL学习|黑马笔记|Day1】数据库概述,SQL|通用语法、SQL分类、DDL
数据库·后端·学习·mysql
mrbone112 小时前
C++-关于协程的一些思考
开发语言·数据库·c++·c++20·协程·异步·coroutines