sql - Snowflake:如何执行 CTAS 或将数据从表 x 复制到 y,其中涉及约束和默认值?
问题描述
我通常使用 CTAS 或 CLONE 将数据从一个表复制到另一个表。问题是我不仅要重命名目标上的相同列,而且还需要:
- 定义约束(在变更表中可以,添加约束)
- 更改列和 SET NOT Null,例如
- 定义 DEFAULT 值不是序列...因此 SF 不支持他的。
那么,如果我什至无法添加默认列,如何实现呢?我的想法是 CTAS,然后更改表以添加列默认值、pks 和其他约束,但默认值失败...
如果我做一个普通的 CTAS,我可以重命名列,但不能保留/更改约束和默认值,可以吗?
有没有办法做到这一点?确实需要将数据从一个模式传输到另一个模式:1 次。
解决方案
您仍然可以使用主键和约束克隆您的基表。然后,您可以重命名克隆表中的列,这不会影响任何关联的约束。例如:
-- 创建一个表作为外键约束
创建或替换表 fk_table(id 整数主键);
-- 创建一个带有主键、默认值和 FK 约束的基表
创建或替换表基表(id整数,dt日期默认current_date,fk整数,主键(id),外键(fk)引用fk_table(id));-- 克隆你的表
创建或替换表clone_table clone basetable;
-- 修改表并重命名部分列 alter table clone_table rename column id to id_new; alter table clone_table 将列 fk 重命名为 fk_new;
-- 获取新对象的 DDL 并确认约束和默认值 -- 已保留
选择 get_ddl('table','clone_table');
推荐阅读
- python - 如何使用 Python 解析 LUA 表并推送到 SQL 数据库?
- python - 在 Jupyter 中切换到 python 3 解释器
- django - 在 Django 表单中动态更新 MultipleChoiceField 选项属性
- c - 无法理解此 statemnet “struct sll_header *shdr = (struct sll_header *)buf;”的语法
- python - /store/ 中的 NoReverseMatch
- python - 从 shell 脚本执行(服务 ssh 启动)有效,但是当我从 python 调用脚本时,它不起作用
- rust - 无法查看我的板条箱功能的文档
- javascript - 如何在每个 Datatable 行中有一个下拉列表?
- python - 是否可以使用 discord.py(从视频中的给定时间戳播放)搜索流式 youtube 音频?
- javascript - 根据列单元格值清除特定行