postgres序列mysql_当Postgres的主键序列不同步时,如何重置它?

pg_get_serial_sequence可用于避免对序列名称的任何错误假设。这在一次尝试中重置了序列:SELECT pg_catalog.setval(pg_get_serial_sequence('table_name', 'id'), (SELECT MAX(id) FROM table_name)+1);

或者更简单地说:SELECT pg_catalog.setval(pg_get_serial_sequence('table_name', 'id'), MAX(id)) FROM table_name;

但是,此表单不能正确处理空表,因为max(Id)是空表,您也不能选择0,因为它超出了序列的范围。解决这一问题的方法之一是求助于ALTER SEQUENCE句法即ALTER SEQUENCE table_name_id_seq RESTART WITH 1;ALTER SEQUENCE table_name_id_seq RESTART; -- 8.4 or higher

但ALTER SEQUENCE使用有限,因为序列名称和重新启动值不能是表达式。

似乎最好的解决办法就是打电话setval使用false作为第三个参数,允许我们指定“下一个要使用的值”:SELECT setval(pg_get_serial_sequence('t1', 'id'), coalesce(max(id),0) + 1, false) FROM t1;

这勾起了我所有的盒子:避免对实际序列名称进行硬编码。

正确处理空表

处理具有现有数据的表,并且不会在序列中留下漏洞。

最后,请注意pg_get_serial_sequence只有当序列属于列时才能工作。如果增量列被定义为serial类型,但是,如果序列是手动添加的,则必须确保ALTER SEQUENCE .. OWNED BY也被执行。

即如果serial类型用于创建表,所有这些都应该工作:CREATE TABLE t1 (

id serial,

name varchar(20));SELECT pg_get_serial_sequence('t1', 'id'); -- returns 't1_id_seq'-- reset the sequence, regardless whether table has

rows or not:SELECT setval(pg_get_serial_sequence('t1', 'id'), coalesce(max(id),0) + 1, false) FROM t1;

但如果手动添加序列:CREATE TABLE t2 (

id integer NOT NULL,

name varchar(20));CREATE SEQUENCE t2_custom_id_seq    START WITH 1

INCREMENT BY 1

NO MINVALUE

NO MAXVALUE

CACHE 1;ALTER TABLE t2 ALTER COLUMN id SET DEFAULT nextval('t2_custom_id_seq'::regclass);ALTER SEQUENCE t2_custom_id_seq OWNED BY t2.id;

-- required for pg_get_serial_sequenceSELECT pg_get_serial_sequence('t2', 'id'); -- returns 't2_custom_id_seq'-- reset the sequence,

regardless whether table has rows or not:SELECT setval(pg_get_serial_sequence('t2', 'id'), coalesce(max(id),0) + 1, false) FROM t1;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值