我通常使用 CTAS 或 CLONE 将数据从一个表复制到另一个表。 问题是我不仅必须重命名目标上的相同列,而且还需要:
那么,如果我什至无法添加默认列,如何实现呢?我的想法是 CTAS 然后更改表以添加列默认值、pks 和其他约束,但它在默认值上失败...
如果我执行普通 CTAS,我可以重命名列,但不能保留/更改约束和默认值,可以吗?
有没有办法做到这一点?确实需要将数据从一种模式转移到另一种模式:1 次。
答案 0 :(得分:2)
您仍然可以克隆带有主键和约束的基表。然后,您可以重命名克隆表中的列,这不会影响任何关联的约束。例如:
-- 创建一个表作为外键约束
创建或替换表fk_table(id整数主键);
-- 创建一个带有主键、默认值和 FK 约束的基表
创建或替换表基表(id 整数, dt 日期默认 current_date, fk 整数, 主键(id), 外键(fk)引用fk_table(id)); -- 克隆你的表
创建或替换表clone_table clone basetable;
-- 更改表并重命名一些列 更改表 clone_table 将列 id 重命名为 id_new; alter table clone_table 将列 fk 重命名为 fk_new;
-- 获取新对象的 DDL 并确认约束和默认值 -- 保存了
select get_ddl('table','clone_table');