【DM8】外部表

外部表是指不存在于数据库中的表。

通过向达梦数据库定义描述外部表的元数据,可以把一个操作系统文件当成一个只读 的数据库表,对外部表将像普通定义的表一样访问。

外部表的数据存储在操作系统文件中,建立外部表的时候,不会产生段,页簇等存储结构,只有与表相关的定义放在数据字典中。在数据库中不能对外部表的内容进行修改,不能对外部表建立主键,索引,外键。不需要将外部表的数据载入到数据库中来,通过SQL解码器来访问外部表。

外部表创建和访问主要步骤如下:

1.创建相关操作系统目录和外部文件;

2.在数据库中定义外部表目录;

3.根据需要定义控制文件(可选);

4.在数据库中创建外部表定义;

5.通过数据库访问外部表。

举例:

根据/opt/emp.txt文件,创建外部表TEST.EMP

bash 复制代码
[root@study ~]# cd /opt/
[root@study opt]# cat emp.txt 
1,a,2019-01-01
2,b,2018-08-08
3,c,1998-10-10
4,d,1988-11-11

1.不用控制文件

创建目录

bash 复制代码
SQL> create directory ddmpdir as '/opt';

图形化界面创建外部表

命令行方式:

bash 复制代码
SQL> create external table TEST.EMP(ID INT,NAME VARCHAR(10),SDATE DATE) from datafile default directory ddmpdir location('emp.txt')parms(fields delimited by ',');
操作已执行
已用时间: 5.204(毫秒). 执行号:5901.
SQL> select * from TEST.EMP;

行号     ID          NAME SDATE     
---------- ----------- ---- ----------
1          1           a    2019-01-01
2          2           b    2018-08-08
3          3           c    1998-10-10
4          4           d    1988-11-11

已用时间: 5.892(毫秒). 执行号:5902.

2.用控制文件

控制文件

bash 复制代码
[root@study opt]# cat emp.ctl 
LOAD DATA
INFILE 'emp.txt'
INTO TABLE TEST.EMP
FIELDS ','

创建目录

bash 复制代码
SQL> create directory empdir as '/opt';

图形化创建表

命令行方式创建表

bash 复制代码
SQL> create external table TEST.EMP(ID INT,NAME VARCHAR(10),SDATE DATE) from default directory empdir location('emp.ctl');
操作已执行
已用时间: 3.684(毫秒). 执行号:5602.

插入成功

bash 复制代码
SQL> select * from TEST.EMP;

行号     ID          NAME SDATE     
---------- ----------- ---- ----------
1          1           a    2019-01-01
2          2           b    2018-08-08
3          3           c    1998-10-10
4          4           d    1988-11-11

已用时间: 18.343(毫秒). 执行号:5603

注意检查:

1.建表的时候注意varchar的值

2.目录权限问题

3.目录是否正确

4.不用控制文件创建外部表的时候,要注意添加分隔符号的参数列表,命令行方式from后面有个datafile default

相关推荐
爱上语文16 分钟前
Redis基础(6):SpringDataRedis
数据库·redis·后端
Java初学者小白35 分钟前
秋招Day14 - Redis - 应用
java·数据库·redis·缓存
丶意冷2 小时前
mybatisPlus分页方言设置错误问题 mybatisPlus对于Oceanbase的Oracle租户分页识别错误
java·数据库·oracle·oceanbase
时序数据说3 小时前
为什么时序数据库IoTDB选择Java作为开发语言
java·大数据·开发语言·数据库·物联网·时序数据库·iotdb
戒不掉的伤怀4 小时前
【Navicat 连接MySQL时出现错误1251:客户端不支持服务器请求的身份验证协议;请考虑升级MySQL客户端】
服务器·数据库·mysql
cv高级工程师YKY4 小时前
服务器 - - QPS与TPS介绍
数据库
nbsaas-boot4 小时前
高可扩展属性建模设计:架构师的全局思考与落地方案
数据库
爱上语文4 小时前
Redis基础(5):Redis的Java客户端
java·开发语言·数据库·redis·后端
陈敬雷-充电了么-CEO兼CTO5 小时前
推荐算法系统系列>推荐数据仓库集市的ETL数据处理
大数据·数据库·数据仓库·数据挖掘·数据分析·etl·推荐算法
MeshddY5 小时前
(超详细)数据库项目初体验:使用C语言连接数据库完成短地址服务(本地运行版)
c语言·数据库·单片机