达梦使用dmfldr和外部表导入txt数据(windows环境)

一、数据准备

1.1 建表

复制代码
CREATE TABLE "SYSDBA"."test"
(
"c1" VARCHAR(1000) NOT NULL,
"c2" VARCHAR(1000),
"c3" VARCHAR(1000),
"c4" VARCHAR(1000),
"c5" VARCHAR(1000),
"c6" VARCHAR(1000),
"c7" VARCHAR(1000),
"c8" VARCHAR(1000),
"c9" VARCHAR(1000),
"c10" VARCHAR(1000),
"c11" VARCHAR(1000),
"c12" VARCHAR(1000),
"c13" VARCHAR(1000),
"c14" VARCHAR(1000),
"c15" VARCHAR(1000),
NOT CLUSTER PRIMARY KEY("c1")) STORAGE(ON "MAIN", CLUSTERBTR) ;

1.2 test.txt数据内容

复制代码
c1c2c3c4c5c6c7c8c9c10c11c12c13c14c15@$%^
001测试1MT03ST01001AT01\N0010001001\N\N\N\N@$%^
001测试2MT01ST01002AT010020020\N\N\N\N\N\N@$%^
001测试3MT01ST01003AT010030021\N\N\N\N\N\N@$%^

二、分别使用以下2种方式导入数据

2.1 dmfldr方式

2.1.1编写控制文件load.ctl

复制代码
OPTIONS (
    skip=1
    rows=50000
    errors=100
	CHARACTER_CODE='UTF-8' --指定字符编码
	NULL_STR='\N'    -- 使用这种方式替换\N 为空
)
LOAD DATA
INFILE 'D:\Desktop\nongxin\test.txt' STR '@$%^
'   --指定行分隔符,直接复制分隔符即可,注意换行,否则第一列会包含换行
BADFILE 'D:\Desktop\nongxin\test.bad' 
replace INTO TABLE "test"     --如果每次导入数据情况,使用replace
FIELDS TERMINATED BY X '1B'       --指定列分隔符ESC的十六进制表示
--TRAILING NULLCOLS
(
	c1   ,
	c2  ,
	c3  ,
	c4  ,
	c5  ,
	c6  ,
	c7  ,
	c8  ,
	c9  ,
	c10  ,
	c11  ,-- "replace(:msgid,'\\N','')", -- 也可以使用这种方式替换\N 为空
	c12  ,
	c13  ,
	c14  ,
	c15    TERMINATED BY '@$%^'
)

2.1.2 cmd进入达梦安装目录bin目录,使用快速装载命令导入数据:

复制代码
E:\dmdbms\bin>dmfldr.exe userid=SYSDBA/密码:端口 control='D:\Desktop\nongxin\load.ctl'

2.1.3 查询表

2.2 外部表方式

2.2.1 创建目录和表

复制代码
#创建目录
 CREATE OR REPLACE DIRECTORY "EXTDIR" AS 'D:\Desktop\nongxin';
#建表
 drop   TABLE ext_test;
 CREATE EXTERNAL TABLE ext_test
(
    c1 VARCHAR(20),
    c2 VARCHAR(100),
    c3 VARCHAR(20),
    c4 VARCHAR(20),
    c5 VARCHAR(50),
    c6 VARCHAR(20),
    c7 VARCHAR(100),
    c8 VARCHAR(20),
    c9 VARCHAR(10),
    c10 VARCHAR(100),
    c11 VARCHAR(50),
    c12 VARCHAR(100),
    c13 VARCHAR(50),
    c14 VARCHAR(50),
    c15 VARCHAR(100)
) 
from DEFAULT DIRECTORY EXTDIR LOCATION ('load.ctl') ; 

2.2.2 编写控制文件(与dmfldr的区别在于INFILE中控制文件的路劲不需要填写)

复制代码
OPTIONS (
    skip=1
    rows=50000
    errors=100
	CHARACTER_CODE='UTF-8' --指定字符编码
	NULL_STR='\N'    -- 使用这种方式替换\N 为空
)
LOAD DATA
INFILE 'test.txt' STR '@$%^
'   --指定行分隔符,直接复制分隔符即可,注意换行,否则第一列会包含换行
BADFILE 'test.bad' 
replace INTO TABLE "test"     --如果每次导入数据情况,使用replace
FIELDS TERMINATED BY X '1B'       --指定列分隔符ESC的十六进制表示
--TRAILING NULLCOLS
(
	c1   ,
	c2  ,
	c3  ,
	c4  ,
	c5  ,
	c6  ,
	c7  ,
	c8  ,
	c9  ,
	c10  ,
	c11  ,-- "replace(:msgid,'\\N','')", -- 也可以使用这种方式替换\N 为空
	c12  ,
	c13  ,
	c14  ,
	c15    TERMINATED BY '@$%^'
)

2.2.3 查询外部表结果

复制代码
 select * from ext_test ;

三、注意事项

相关推荐
wsy_6662 小时前
docker
java·spring cloud·docker
1104.北光c°2 小时前
【黑马点评项目笔记 | 商户查询缓存篇】基于Redis解决缓存穿透、雪崩、击穿三剑客
java·开发语言·数据库·redis·笔记·spring·缓存
历程里程碑2 小时前
Linux19 实现shell基本功能
linux·运维·服务器·算法·elasticsearch·搜索引擎·哈希算法
阿萨德528号2 小时前
MyBatis OGNL 表达式陷阱:Integer类型字段使用“xxx!= ‘‘”时判断失效
java·开发语言·mybatis
数据知道2 小时前
PostgreSQL 核心原理:一文掌握数据库的热数据缓存池(共享缓冲区)
数据库·缓存·postgresql
上海合宙LuatOS2 小时前
LuatOS 框架的设计原理
java·开发语言·单片机·嵌入式硬件·物联网·硬件工程
璞~2 小时前
面试题文件断点续传怎么实现?
java
霍格沃兹测试学院-小舟畅学2 小时前
Playwright测试超时管理:全局与局部超时设置
运维·服务器·网络
毕设源码-赖学姐2 小时前
【开题答辩全过程】以 高校网上订餐系统为例,包含答辩的问题和答案
java