>我有一个带有列的.csv表(t1):亚马逊S3存储中的c1,c2,c3
>我想将其复制到亚马逊红移中
>我使用列创建表:c1,c3,其中所有列都可以为空
>我用命令复制:
>我想将其复制到亚马逊红移中
>我使用列创建表:c1,c3,其中所有列都可以为空
>我用命令复制:
复制t1a(c1,c3)
从t1
>我预计它会从t1复制c1和c3并将默认的空值放在c2中,因此t1a中的一行可能看起来像(c1_rowX,null,c3_rowX).
>相反,我得到一个类型错误,因为它将来自t1的c2(字符串类型)数据复制到t1a的c3(int类型).
>当我没有指定列时,copy命令工作正常:
复制t1a
从t1
>我已经包含了一个指向redshift copy命令文档的链接:
http://docs.aws.amazon.com/redshift/latest/dg/r_COPY.html
>主要问题是我使用指定列的问题.谢谢
如果要跳过预处理部分,可以将要跳过的列定义为CHAR(1),然后将TruncATECOLUMNS参数用于copY命令:
CREATE TABLE t1a ( c1,c2 CHAR(1),c3 ); copY t1a FROM t1 TruncATECOLUMNS
TruncATECOLUMNS忽略导入期间比表模式中定义的更长的所有数据,因此该列中的所有数据将被截断为1个字符.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。