GaussDB 数据导入导出工具介绍

news/2025/1/22 12:50:08/文章来源:https://www.cnblogs.com/xiaoxu0211/p/18512157

一、数据导入导出场景划分

在这里插入图片描述

  1. gsql工具适用场景和使用方法

适用场景
文本格式对象定义的创建

使用方法

gsql -d db1 -p 16000 -U u1 -W Huawei@123 -f/data/table.sql

示例:

ALTER SESSION SET CURRENT_SCHEMA = PUBLIC;ALTER TABLE "PUBLC".GA_COM_COLLECTION_ERROR_TABLEMODIFY MESSAGE VARCHAR(4000);
ALTER TABLE "PUBLIC".GA_COM_COLLECTION_ERROR_TABLE ADDCOLUMN FRRORCOUNTINT NUL DEEAULT O;
ALTER TABLE "PUBLIC".GA_COM_COLLECTION_ERROR_TABLE ADDCOLUMN PLUGINID VARCHAR (50)NULL;
ALTER TABLE "PUBLIC".GA_COM_COLLECTION_ERROR_TABLE ADDCOLUMN IS ALARM RAISED INT NULL DEFAULT O;
CREATE INDEX GA_COM_COLLECTION_ERROR_TABLE_IDX ON
"PUBLIC".GA_COM_COLLECTION_ERROR_TABLE(CLUSTERID,PLUGINID);CREATE OR REPLACE FUNCTION GenerateSnapshotID()RETURN BIGINT ISSnapID BIGINT;
BEGINSELECT"PUBLIC".GA_COM_COLLECTION_SNAPSHOT_SEQ.nextval intoSnaplD from SYS_DUMMY;RETURN SnapID;
END;
  1. copy使用场景和使用方法

copy是数据库服务端的命令,只能在服务端执行数据导入,\copy则可以在客户端执行命令。
适用场景

小数据量表以文本数据作为来源导入;

小数量表的导出,查询结果集导出;

使用方法

文本数据导入:

copy t1 from '/data/input/t1.txt'delimiter ',';

表数据导出:

copy t1 to '/data/input/t1 output.txt' delimiter ',';

查询结果集导出:

copy (select * from t1 where a2=1) to '/data/input/t1 output.txt'delimiter ',';

注:分布式场景中,copy from/to是从CN端进行数据的导入导出,与GDS方式相比性能较低。

数据文件示例(CSV)

1,AAAA,842334595,LKDHSGWIE04OKJNGOERI20ONG
2,BBBB,842339356,KBJASAKDGNIASKDGNOKRMKNGA
3,CCCC,840282591,JBIASKDG10JT3409JNLG0123L
4,DDDD,842871486,LKSD8498LJFG71LKLJASNDGDS
5,EEEE,8429897130,SD81KNA0LAKJG0O4L23NL1KN
6,FFFE,842334595,LLA0AKJN88ASJDGN6LK3LKLNA
7,GGGG,840148810,LKDHSGWIE04OKJNI20ONGLSDK
8,HHHH,846768299,YUIHBRIASASD8BDKHDBFAIS2L
9,IIII,847990809,YNBBV2VXZUODJNFAKS3498YBS
10,JJJJ,842334595,SDUGBAKSHD874TI1BGPO14J
11,KKKK,827592226,T9134F90AKLSAJOIKAJSDFFYA
12,LLLL,842334595,LKDHSGWIE04OKJNGOERIGLSDK
13,MMMM,842849111,YJASDHA690HASJ013B01B102
14,NNNN,842334595,JBIASKDG10JTJNLASDKG0123L
15,OOOO,847465286,JZZXKCEBO02392NOFKS0120NS
16,PPPP,842334595,YNBBZUOWEISDJNFAKS3498YBS
17,QQQQ,842334595,LKDHSGWIE040KJNGOERI20ONG
18,RRRR,848347289,U98KHNASDY9OABSDGVSD9JBO0
19,SSSS,842334595,YNBBV2VXZUOWEISDJN3498YBS
20,TTTT,842334595,LKDHSGWIE04OKJRI20ONGLSDK
21,UUUU,847187929,LLA0AKJN88GN6LK3LK32NLLTA
22,VVVV,842334595,LKSD849G71LJASOKLJASNDGDS
23,WWWW,847592917,OKNA0LAKJG0Q4L23NL1KNL1N
JDBC中使用copy

适用于copy的场景中,编程的方式导入数据;

使用方法

private void metadataToDB(){try {CopyManager cpManager = new CopyManager((BaseConnection) conn);
//清理数据库中已有数据,可选st.executeUpdate( "TRUNCATE TABLE metadata;");String metaFile = this.dataDirectory + File.separator+this.metadataFile.this.logger.log(Level.INFO, "Importing metadata from " + metaFile);long n = cpManager.copyln( "COPY metadata FROM STDIN WITH CSV" , new
FileReader(metaFile));this.loggerlog(Level.INFO, n + " metadata imported");} catch(Exception e){e.printStackTrace();System.exit(1);}
}

gs_dump/gs_restore适用场景
适用场景

导出、恢复整个数据库对象定义:用户可以自定义导出一个数据库或其中的对象(模式、表、视图等)。

以Sql语句进行导入、导出:导入导出为.sql文件格式为纯本格式。

避开业务高峰期,避免操作失败:gs_dump工具在进行数居导出时,其他用户可以访问数据库数据库(读或写)。

3.gs_dump工具使用方法

导出单表定义

gs_dump mydb -U u1 -W Huawei@123 -p 16000 -s -t t1 -f /data/t1.sql -F c

导出整个数据库对象

gs_dump mydb -p 16000 -s -f /data/all.sql

导出数据库所有对象和数据

gs_dump mydb -p 16000 -f /data/all.sql

导出文件示例

SET statement timeout = 0;
SET xmloption = content;
SET client_encoding = 'SQL ASCII';
SET standard_conforming strings = on;
SET check_function_bodies = false;
SET client_ min_messages = warning;SET search_path = public;
SET default_tablespace = ";
SET default_with oids = false;--
--Name: t1; Type: TABLE; Schema: public; Owner: rdsAdmin; Tablespace:
--CREATE TABLE t1(name text,age integer
)
WITH (orientation=row,compression=no)
DISTRIBUTE BY HASH(name);ALTER TABLE public.t1 OWNER TO "rdsAdmin";--
--Data for Name: t1; Type: TABLE DATA; Schema: public; Owner:rdsAdmin
--COPY t1 (name, age) FROM stdin;
st                   27
\.
;
  1. gs_restore工具使用方法

gs_restore恢复数据库对象:gs_restore工具支持的格式包括自定义归档、目录归档和tar归档格式。1、执行gsql程序,使用如下选项导入由gs_dump/gs_dumpall生成导出文件夹(纯文本格式)的

MPPDB_backup.sql文件到mydb数据库。

gsql -d mydb -p 8000 -f
/home/omm/test/MPPDB_backup.sal
Password:
SET
ALTER TABLE
CREATE INDEX
REVOKE
GRANT
total time: 30476 ms

示例中"-f"后的是导出的文件,"8000"表示数据库服务器端口;"mydb"表示要访问的数据库名。
2、执行gs_restore,将导出的MPPDB_backup文件(目录格式)导入到mydb数据库。

示例:执行成功

gs_restore backup/MPPDB_backup -p 8000 -d mydb
Password:
gs_restore[2017-07-21 19:16:26]: restore operation
successful
gs_restore[2017-07-21 19:16:26]: total time: 21003 ms

示例:执行失败

gs_restore backup/MPPDB_backup -p 8000 -d mydb
Error while PROCESSING TOC:
Error from Toc entry 6245:0 18719 TABLE DATA
ga_an_an failure_report_detail apprim
COPY failed for table "ga_an_an_failure_report_detail": ERROR: duplicate key value violates unique constraint "ga_an_an_failure_report_detail_pkey1"
DETAlL: Key (faildetailid)=(1) already exists.
CONTEXT: COPY ga_an_an_failure_report_detail, line 13: ""
table ga_pl_ap_upgradelog complete data imported !
Finish reading 30 SQL statements!
end restore operation ...
WARNING: errors ignored on restore: 1
restore operation successful
total time:150 ms

二、gs_loader介绍

  1. 工具介绍

gs_loader工具是一款兼容Oracle的sqlldr的导入工具,语法基本兼容Oracle的sqlldr。
适用场景

Oracle的sqlldr兼容场景的导入

可以设置导入的容错性

当前只支持集中式

原理介绍

将控制文件支持的语法转换为\COPY语法,然后利用已有的\COPY功能,实现数据导入工作。

gs_loader使用方法-导入
1.创建用户并授予使用权限

CREATE USER load_user WITH PASSWORD '************';
GRANT ALL ON FUNCTION copy_error_log_create() TO load_user;
GRANT ALL ON SCHEMA public TO load_user;
SELECT copy_error_log_create();
SELECT copy_summary_create();
GRANT ALL PRIVILEGES ON public.pgxc_copy_error_log Toload_user;
GRANT ALL PRIVILEGES ON public.gs_copy_summary To load_user;

2.创建系统表和数据表
select copy_summary_create();--gs_copy_summary记录执行结果汇总,包括成功行数,出错行数,忽略行数,空行数。

Select copy_error_log_create();--错误表pgxc_copy_error_log 。
503.1.SPC1300及以后版本之后无需再创建错误表

3.创建控制文件ctl

LOAD DATA
truncate into table loader_tbl
WHEN name = 'Jack'
fields terminated by ','
trailing nullcols
(id integer externalname char(32),con "length(name)",dt date
)

4.数据文件data.csv示例

1,OK,2007-07-8
2,OK,2008-07-8
3,OK,2009-07-8
a,OK,2007-07-8
43,DISCARD,,2007-07-8"'
32,DISCARD,,2007-07-8
a,ERROR int,,2007-07-8
8,ERROR date,2007-37-8
""
'
8,ERROR fields,,2007-37-8'"
5,OK,,2021-07-30

5.进行导入

gs_loader control=loader.ctl data=data.csv db=testdb discard=loader.dis
bad=loader.bad errors=5 port=8000 passwd=************ user=load_user

6.执行结果
gs_loader: version 0.1 10 Rows successfully loaded.log file is: Loader.log
gs_loader控制文件格式
控制文件示例

LOAD DATA
truncate into table salldr_tbl
fields terminated by ','
WHEN name ='Jack'
trailing nullcols
(id integer external,name char(32),dt date
)

a.sqlldr_tbl是目标表名,truncate表示如果表中有数据,则全部删除后再导入,可选值包括:insert、append、replace、truncate。
b.fields terminated by ',’表示数据文件中按 ',’分隔字段。
C.WHEN name =‘Jack’ 表示根据name过滤,只导入name= 'Jack’的数据。
d.小括号 中定义了导入的字段列表。id为字段名称,integer external为字段类型

1)普通数据类型: char. integer external. float external. decimal external. timestamp, date, date external. sysdate
2)特殊数据类型: integer、smallint、raw
e.以上为控制文件的简单示例,完整格式参考集中式《GaussDB Kernal 工具参考》中“客户端工具-gs_loader”章节。

gs_loader特性:支持position
1.使用场景:通过字段起始和结束位置来获取对应字段
2.使用方法:在控制文件字段列表中指定position,如下所示:

LOAD DATA
truncate into table sqlldr_tbl
trailing nullcols
(id position(1:4)integer external,name position(5:6) char(32)
) 

gs_loader特性:支持列表达式
1.使用场景:使用表达式对数据进行变换后再插入目标表中
2.使用方法:在控制文件字段列表中指定列表达式,如下所示:

LOAD DATA
truncate into table salldr_tbl
fields terminated by ','
trailing nullcols
(id integer external,name char(32)"trim(:name)"address char(8)"replace(:address, ':'. '_')"money integer external “case when :money<1000 then 0 else :money-1000 end'

gs_loader特性:按行提交
1.rows 命令行参数介绍
不指定rows参数时,rows无默认取值,表现为只进行一次提交,即所有数据都导入表中后进行一次事务提交。

参数指定每导入多少行数据后就进行一次提交,可以避免导入大量数据时因为失败,导致前功尽弃。

gs loader control=loader.ctl data=data.csv db=testdb discard=loader.dis bad=loader.bad
errors=5 rows=10000 port=8000 passwd=************ user=load_user
这里的rows=10000表示每成功导入10000行提交一次

2.最佳实践
单次导入提交次数不建议超过1000次,否则可能会对性能产生影响。
提交次数约等于数据文件中数据总行数除以rows参数取值。

GDS介绍
工具介绍
GDS(Gauss Data Service)工具,用于解决分布式场景下大数据量数据导入导出慢的问题。通过DN并行导入导出,解决了CN在分布式常规导入导出的瓶颈问题,极大提升了导入导出的效率。

适用场景

分布式场景下大数据量表以文本数据作为来源导入。

大数据量表的导出。

可以设置导入的容错性。

离线导入。

GDS原理介绍
传统单节点导入性能低,通过GDS工具充分利用多节点并行导入,提高整体导入性能:

1、CN节点只负责任务的规划及下发,把数据导入的工作交给了DN节点,释放了CN节点的资源。
2、GDS进程负责数据文件的切分,然后分发给各个DN实例。
3、各DN实例接收到数据分片后解析数据,而后根据表的分布列计算hash值,确定该条数据属于哪个DN;如果属于自身则缓冲中到本地,如果属于别的DN则通过网络发送给相应的DN。

Foreian Table:
用于识别源数据文件的位置、文件格式、存放位置、编码格式、分隔符等信息;是关联数据文件与数据库实表(目标表)的对象。

三、GDS使用方法-导入示例

1.启动GDS服务

gds-d/input_data/-p10.186.251.85:8808-H0.0.0.0/0 -/log/gds_log.txt -D -t2

2.创建外表

create foreian table t1_foreiqn(a1 varchar2(10),a2 int)SERVER qsmpp_server OPTlONS (location 'gsfs://10.186.251.85:8808/t1.txt'format 'text',encoding 'utf8’,delimiter '^',null ") per node reject limit 'value'with error_ftr_sbtest2; 

3.执行导入

insert into t1 select * from t1_foreign;

四、GDS使用方法-导入错误表分析

1.错误表

2.常见导入错误

invalid byte sequence for encoding "“UTF8"”:0x00

文本数据中含有对UTF8来说非法字符的编码0x00,需要用命令进行清理tr-s“八000]“”“八040*]”outputfile,后续版本提供错误数据入库选项。

missing data for column “a2”

错误数据行缺失列。

value too long for type character varying(10)

错误数据行的字段值超过表定义字段长度。

五、GDS使用方法-导出

1.启动GDS服务

gds -d /input_data/-p 192.168.0.90:5000 -H10.10.0.1/24 -I/log/gds_log.txt -D -t 2

2.创建外表

create foreian table t1_foreian output(a1 yarchar2(10), a2 int)SERVER gsmpp_server OPTlONS (location 'gsfs://10.185.240.41:8000/',format 'text',encoding 'utf8', delimiter'^',nul ")write only;

3.执行导出

insert into t1_foreign_output select * from t1;

导出的文本命名格式为t1_foreign_output.dat.0

​https://support.huaweicloud.com/intl/zh-cn/gaussdb/index.html​​

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/823567.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

tag 转 branch 前 记得 Fetch 一下 - git基础

tag 转 branch 前 记得 Fetch 一下 - git基础 遇到的问题 当直接在远程的gitlab创建一个新的tag的时候(非本人创建),你本地是没有这个tag,所以你直接用这个tag名称转branch,会出现找不到tag的情况,需要Fetch一下即可。--------------------------------------------- 生活…

GaussDB多租组件

云原生数据库支持多租户,通过多租户资源共享,一是降低租户的成本,二是通过共享资源的池化实现租户的资源弹性,提高租户业务的可用性。 租户的资源弹性支持两种模式,Scale Up和Scale Out。Scale Up是在单个计算节点上对租户的分配资源进行弹性处理,Scale Out是在计算节点之…

Attention mechanism目前有什么缺点和改进空间

Attention mechanism是自然语言处理和计算机视觉领域的一项重要技术,但存在一些缺点和改进空间。主要缺点包括:1.计算复杂性高;2.缺乏解释性;3.可能产生不必要的注意力分配;其中,计算复杂性高可能限制了在大规模数据上的应用。改进方向包括:1.优化算法效率;2.增强模型解…

PbootCMS登录后权限不足怎么办

登录后权限不足问题描述:登录后无法访问某些功能或页面,提示权限不足。 解决方案:检查用户角色和权限:确保当前用户的角色和权限设置正确。 检查权限配置:检查PBootCMS的权限配置文件,确保没有错误的配置。 重新分配权限:在后台管理中,重新分配用户的角色和权限。 检查…

PbootCMS网站打开提示:“无法连接到数据库!”

网站打开提示:“无法连接到数据库!”问题原因:数据库配置不正确或数据库服务未启动。 解决方法:检查 config/database.php 文件中的数据库配置信息是否正确,包括数据库地址、端口、用户名、密码和数据库名称。 确保数据库服务已启动,并且可以从 Web 服务器访问。扫码添加…

智子: Vue Vapor年底发布alpha版本,如果有资金支持

前言 在最近的Vue Fes大会上,Vue Vapor的作者智子大佬宣布,如果能够得到资金支持,那么Vue Vapor年底就能发布alpha版本了。 关注公众号:【前端欧阳】,给自己一个进阶vue的机会 智子也需要赚钱养活自己 根据尤大透露,过去一年以来智子接受赞助全职在为Vue Vapor工作。现在…

帝国cms调用当前顶级栏目下所有下级子栏目并且当前高亮显示啊

[e:loop={"select classname,classpath,classid from phome_enewsclass where bclassid=".$class_r[$GLOBALS[navclassid]][bclassid]." order by myorder,classid desc ",0,24,0}] <?php $classurl=sys_ReturnBqClassname($bqr,9);?> <a href=…

帝国cms一句MySQL语句实现多表数据之和

SQL语句:SELECT COUNT(AA.id) AS total FROM (SELECT id FROM www_moban5_cn_ecms_newsUNION ALLSELECT id FROM www_moban5_cn_ecms_xiazaiUNION ALLSELECT id FROM www_moban5_cn_ecms_photoUNION ALLSELECT id FROM www_moban5_cn_ecms_download ) AA;在帝国CMS后台使用:SEL…

无缝对接,高效协同:能源电力行业的文件摆渡方案新鲜出炉!

在能源电力行业,涉及大量敏感信息和重要数据需要得到严格保护,比如电力生产与供应链数据、电网运行与维护数据、用户信息与用电数据、研发与创新数据等。随着企业的不断发展,企业数字化转型的逐渐深入,需要重点关注数据安全。因此大部分能源电力企业会将网络划分成内网和外…

PbootCMS 织梦后台左侧菜单空白不显示的解决办法

权限问题:检查 data 文件夹及其子文件夹是否有写入权限,确保在Linux和Windows系统中都正确设置了权限。 对于Linux系统,可以通过命令行使用 chmod -R 777 data 命令赋予写入权限;对于Windows系统,则需要通过文件属性手动设置。缺少必要的文件夹:如果 /data/cache/, /data…

怎么修改网站后台标题?怎样修改企业网站密码?

修改网站后台标题登录后台管理:首先,你需要登录到你的网站后台管理系统。找到设置选项:通常在后台管理界面的顶部或侧边栏会有“设置”、“系统设置”或“站点设置”等选项。编辑标题:在设置页面中,找到“网站标题”、“站点名称”或类似的字段,输入你想要的新标题。保存…

dedeCMS 织梦模板批量替换代码后页面变成空白和标签的解决办法

原因:批量替换模板代码时使用目录查找方式引起。 解决方法:打开出现问题的模板文件,在任意位置敲入一个空格,保存文件,重新生成即可。 若多个模板文件受影响,需逐一操作。扫码添加技术【解决问题】专注中小企业网站建设、网站安全12年。熟悉各种CMS,精通PHP+MYSQL、HTML…