雪花:如何执行 CTAS 或将数据从表 x 复制到 y 并涉及约束和默认值?

如何解决雪花:如何执行 CTAS 或将数据从表 x 复制到 y 并涉及约束和默认值?

我通常使用 CTAS 或 CLONE 将数据从一个表复制到另一个表。 问题是我不仅必须重命名目标上的相同列,而且还需要:

  1. 定义约束(在变更表中可以,添加约束)
  2. 例如更改列和设置非空
  3. 定义 DEFAULT 值是 not 序列...因此 SF 不支持他的。

那么,如果我什至无法添加认列,如何实现呢?我的想法是 CTAS 然后更改表以添加认值、pks 和其他约束,但它在认值上失败...

如果我执行普通 CTAS,我可以重命名列,但不能保留/更改约束和认值,可以吗?

有没有办法做到这一点?确实需要将数据从一种模式转移到另一种模式:1 次。

解决方法

您仍然可以克隆带有主键和约束的基表。然后,您可以重命名克隆表中的列,这不会影响任何关联的约束。例如:

-- 创建一个表作为外键约束

创建或替换表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');

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?