You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

如何导出与执行语句格式一致的数据库Schema Dump?

如何导出与原CREATE TABLE格式一致的Schema

这问题我之前维护数据库时也碰到过!本质原因是PostgreSQL的默认导出工具(pg_dump)会把主键这类约束单独拆成ALTER TABLE语句(放在备份的post-data段),方便带外键的表批量恢复,但就会出现和你创建时格式不一致的情况。下面给你两种靠谱的解决办法:

方法一:用pg_dump的--inline-constraints参数(PostgreSQL 12+适用)

如果你用的是PostgreSQL 12或更高版本,官方已经提供了直接生成内联约束的参数。只需要在导出schema时加上这个参数就行,命令如下:

pg_dump --schema-only --inline-constraints -d 你的数据库名 > schema.sql

导出后的SQL文件里,CREATE TABLE语句就会和你当初写的一样,把主键直接定义在字段后面:

CREATE TABLE a( id integer PRIMARY KEY );

方法二:用pgAdmin图形界面(全版本适用)

如果你的PostgreSQL版本较低,或者更习惯用图形界面操作,可以用pgAdmin来导出:

  • 右键点击目标数据库,选择「备份」
  • 在备份窗口里,把「格式」设置为「纯文本」
  • 切换到「选项」标签页,找到「Schema」区域,勾选「内联约束」(Inline constraints)
  • 点击「备份」生成SQL文件,里面的表结构就会保持内联主键的格式了

补充说明

pg_dump默认拆分约束的逻辑是为了优化带外键关联的数据库恢复:先创建所有空表,再统一添加约束,避免因为表创建顺序导致外键依赖报错。但如果只是导出单个表或者不需要考虑外键恢复顺序的场景,用上面的方法就能得到和原创建语句格式一致的Schema啦。

内容的提问来源于stack exchange,提问作者Василий Орешко

火山引擎 最新活动