设为首页 加入收藏

TOP

如何把其他数据库中AUTO_INCREMENT约束的字段(如ID)导入Vertica数据库
2014-11-23 23:25:42 来源: 作者: 【 】 浏览:2
Tags:如何 其他 数据库 AUTO_INCREMENT 约束 导入 Vertica

如果在Vertica数据库在建一张同样带AUTO_INCREMENT约束字段(ID)的表,由于AUTO_INCREMENT约束的限制,COPY导入数据时会发生冲突,导致COPY执行失败。

经过分析研究及测试,先创建SEQUENCE,然后创建表并设置ID字段的缺省值为NEXTVAL('schemaname.sequencename'),就可COPY导入AUTO_INCREMENT约束字段的数据。步骤如下:

1、创建SEQUENCE:

create SEQUENCE public.mytab_id_seq;

2、创建表:
CREATE TABLE IF NOT EXISTS public.mytab (
id bigint NOT NULL DEFAULT NEXTVAL('public.mytab_id_seq') UNIQUE PRIMARY KEY,
...
);

3、导入数据:
copy public.mytab ( we_id,...) from '/home/username/mytab.csv' DELIMITER '|';

4、查询ID的最大值:

select max(id) from mytab;

5、修改SEQUENCE的初始值为ID的最大值(如720):

ALTER SEQUENCE public.mytab_id_seq RESTART WITH 720;

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Hive.GROUPINGSETS有BUG? 下一篇[NOSQL]Memcache入门

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: