file_dw简介

​ file_fdw模块提供外部数据包装器file_fdw, 它能被用来访问服务器的文件系统中的数据文件,或者在服务器上执行程序并读取它们的输出。 数据文件或程序输出必须是能够被COPY FROM读取的格式. 详见COPY。当前只能读取数据文件。

参数设置:

  • filename

    指定要被读取的文件。必须是一个绝对路径名。 必须指定filename或program, 但不能同时指定两个。

  • program

    指定要执行的命令。该命令的标准输出将被读取, 就像使用COPY FROM PROGRAM一样。必须指定program 或filename,但不能同时指定两个。

    注意该命令是由 shell 调用,因此如果你需要传递任何来自不可信来源的 参数给 shell 命令,你必须小心地剥离那些可能对 shell 有特殊意义的特殊字符。出于安全原因,最好使用一个固定的命令字符串,或者至少避免传递任何用户输入到其中。

  • format

    指定数据的格式:text、 csv(逗号分隔值)或者binary。默认是text

  • header

    指定数据是否具有一个头部行,指定文件包含标题行,其中有每一列的名称。在输出时,第一行包含来自表的列名。在输入时,第一行会被忽略。只有使用 CSV格式时才允许这个选项。。

  • delimiter

    指定分隔文件每行中各列的字符。文本格式中默认是一个制表符,而CSV格式中默认是一个逗号。KingbaseES支持设置不大于8个字节的分隔符。使用binary格式时不允许这个选项。

  • quote

    指定数据的引用字符,默认是双引号。这必须是一个单一的单字节字符。只有使用 CSV格式时才允许这个选项。

  • escape

    指定数据的转义字符,这必须是一个单一的单字节字符。只有使用 CSV格式时才允许这个选项。

  • null

    指定数据的空字符串,指定表示一个空值的字符串。文本格式中默认是 \N(反斜线-N),CSV格式中默认是一个未加引用的空串。在你不想区分空值和空串的情况下,即使在文本格式中你也可能更喜欢空串。使用binary格式时不允许这个选项。。

  • encoding

    指定数据的编码,和COPY的ENCODING选项相同。

file_fdw使用

以下测试基于kingbase v8r6版本:

1.将file_fdw 安装为 一个扩展

test=# create extension file_fdw;
CREATE EXTENSION

2.创建一个外部服务接口

test=# create server ser_file_fdw foreign data wrapper file_fdw;
CREATE SERVER 查询已创建的外部服务接口
test=# \des
外部服务器列表
名称 | 拥有者 | 外部数据封装器
--------------+--------+----------------
ser_file_fdw | system | file_fdw
sysaudit_svr | system | sysaudit_fdw
(2 行记录)

3.通过program方式创建外部表

test=# CREATE FOREIGN TABLE etc_password (
test(# username TEXT,
test(# password TEXT,
test(# user_id INTEGER,
test(# group_id INTEGER,
test(# user_info TEXT
test(# ) SERVER fs OPTIONS (
test(# PROGRAM
test(# $$
test$# awk -F: 'NF && !/^[:space:]*#/ {print $1,$2,$3,$4,$5}' OFS='\037' /etc/passwd
test$# $$
test(# ,
test(# FORMAT 'csv', DELIMITER E'\037'
test(# );
CREATE FOREIGN TABLE
test=# select * from etc_password;
username | password | user_id | group_id | user_info
------------------+----------+---------+----------+-----------------------------------------------------------------
root | x | 0 | 0 | root
bin | x | 1 | 1 | bin
daemon | x | 2 | 2 | daemon
adm | x | 3 | 4 | adm
lp | x | 4 | 7 | lp
sync | x | 5 | 0 | sync
shutdown | x | 6 | 0 | shutdown
halt | x | 7 | 0 | halt
mail | x | 8 | 12 | mail
operator | x | 11 | 0 | operator
games | x | 12 | 100 | games
ftp | x | 14 | 50 | FTP User
nobody | x | 65534 | 65534 | Kernel Overflow User
systemd-coredump | x | 999 | 997 | systemd Core Dumper
systemd-network | x | 192 | 192 | systemd Network Management
systemd-resolve | x | 193 | 193 | systemd Resolver
systemd-timesync | x | 998 | 996 | systemd Time Synchronization
tss | x | 59 | 59 | Account used by the trousers package to sandbox the tcsd daemon
unbound | x | 997 | 995 | Unbound DNS resolver
polkitd | x | 996 | 994 | User for polkitd
rtkit | x | 172 | 172 | RealtimeKit
chrony | x | 995 | 993 |
dhcpd | x | 177 | 177 | DHCP server
sshd | x | 74 | 74 | Privilege-separated SSH
geoclue | x | 994 | 990 | User for geoclue
pulse | x | 171 | 171 | PulseAudio System Daemon
tcpdump | x | 72 | 72 |
dbus | x | 987 | 987 | System Message Bus
apache | x | 48 | 48 | Apache
kingbase | x | 1000 | 1000 |
test | x | 1001 | 1001 |
kdb1 | x | 1002 | 1002 |
(32 rows)

​ 4.通过csv创建一个外部表

创建test.csv内容如下

ID    ID2   NAME
2 55 single
6 58 multiple
8 53 single 根据csv文件创建外部表 test=# CREATE FOREIGN TABLE foreign_tab (
test(# "ID" character varying(50 char) NULL,
test(# "ID2" integer NULL,
test(# "NAME" character varying(50 char) NULL
test(# ) SERVER ser_file_fdw
test-# OPTIONS ( filename 'C:\Program Files\Kingbase\ES\V8\data\ECRecord.CSV',format 'csv', HEADER 'TRUE' );
CREATE FOREIGN TABLE test=# SELECT * FROM FOREIGN_TAB;
ID | ID2 | NAME
----+-----+----------
2 | 55 | Single
6 | 58 | Multiple
8 | 53 | Single
(3 行记录)

对外部表的操作,外部表不支持insert ,update和delete操作。

1.连接查询

test=# select * from t1;
f_rowid | dingdan | yaopin
---------+----------+--------
1 | d001 | c001
3 | d003 | c003
2 | Single | c002
6 | Multiple | c006
11 | Single | Single
(5 行记录) test=# SELECT * FROM foreign_tab f ,t1 b WHERE f.id=b.f_rowid;
ID | ID2 | NAME | f_rowid | dingdan | yaopin
----+-----+----------+---------+----------+--------
2 | 55 | Single | 2 | Single | c002
6 | 58 | Multiple | 6 | Multiple | c006
(2 行记录) 2.merge 操作 由于外部表不支持delete insert update操作,merge时外部表只能做参照表 test=# select * from t1;
f_rowid | dingdan | yaopin
---------+----------+--------
1 | d001 | c001
3 | d003 | c003
2 | Single | c002
6 | Multiple | c006
(4 行记录) test=# select * from foreign_tab;
ID | ID2 | NAME
----+-----+----------
2 | 55 | Single
6 | 58 | Multiple
8 | 53 | Single
(3 行记录) test=# merge into t1 a using foreign_tab b
test-# on (a."f_rowid" = b.id)
test-# when matched then update set dingdan=b.id2
test-# when not matched then insert values(b.id, b.id2,b.name);
MERGE 3
test=# select * from t1;
f_rowid | dingdan | yaopin
---------+---------+--------
1 | d001 | c001
3 | d003 | c003
2 | 55 | c002
6 | 58 | c006
8 | 53 | Single
(5 行记录)

file_fdw卸载

​ 在ksql中运行drop命令进行卸载 如果有外部表依赖则需要加cascade

test=# drop extension file_fdw;
DROP EXTENSION 存在依赖:
test=# drop extension file_fdw;
错误: 无法删除 扩展 file_fdw 因为有其它对象倚赖它
描述: 服务器 pglog 倚赖于 外部数据封装器 file_fdw
外部表 ECRecord_new 倚赖于 服务器 pglog
外部表 ECRecord_new2 倚赖于 服务器 pglog
外部表 ECRecord_new3 倚赖于 服务器 pglog
外部表 ECRecord_new4 倚赖于 服务器 pglog
提示: 使用 DROP .. CASCADE 把倚赖对象一并删除.
test=# drop extension file_fdw cascade;
注意: 串联删除5个其它对象
描述: 递归删除 服务器 pglog
递归删除 外部表 ECRecord_new
递归删除 外部表 ECRecord_new2
递归删除 外部表 ECRecord_new3
递归删除 外部表 ECRecord_new4
DROP EXTENSION

file_fdw升级

​ file_fdw扩展插件通常随着KingbaseES安装包一并升级。通常情况下用户无须单独升级些插件。

KingbaseES file_dw 介绍的更多相关文章

  1. KingbaseES DBLink 介绍

    DBLink 扩展插件功能与 Kingbase_FDW 类似,用于远程访问KingbaseES 数据库.相比于Kingbase_FDW,DBLink 功能更强大,可以执行DML,还可以通过 begin ...

  2. KingbaseES触发器介绍

    触发器及其作用 触发器(trigger)是用户定义的由事件驱动的特殊过程.一旦定义,所有用户的对应操作均会由服务器自动激活相应的触发器,在DBMS核心层进行集中的完整性控制. 触发器类似于约束,但是比 ...

  3. KingbaseES 全文检索功能介绍

    KingbaseES 内置的缺省的分词解析器采用空格分词,因为中文的词语之间没有空格分割,所以这种方法并不适用于中文.要支持中文的全文检索需要额外的中文分词插件:zhparser and sys_ji ...

  4. KingbaseES DBLink 扩展介绍

    DBLink 扩展插件功能与 Kingbase_FDW 类似,用于远程访问KingbaseES 数据库.相比于Kingbase_FDW,DBLink 功能更强大,可以执行DML,还可以通过 begin ...

  5. KingbaseES 工具sys_dump,sys_restore使用介绍

    说明: KingbaseES V8R6版本中自带数据库备份导出sys_dump,和备份恢复sys_restore工具. sys_dump:把KingbaseES数据库抽取为一个脚本文件或其他归档文件. ...

  6. KingbaseES interval 分区表介绍

    KingbaseES从V008R006C005B0041版本开始支持Oracle的Interval分区表功能. Interval分区表是一种特殊的范围分区表.当执行INSERT或者UPDATE时,若数 ...

  7. KingbaseES 数据脱敏功能介绍

    数据脱敏,指对某些敏感信息通过脱敏规则进行数据的变形,实现敏感隐私数据的可靠保护. KingbaseES主要提供动态数据脱敏功能. 动态数据脱敏(Dynamic Data Masking)是与生产环境 ...

  8. KingbaseES 中 JSON 介绍

    KingbaseES支持JSON和JSONB.这两种类型在使用上几乎完全一致,主要区别是 JSON类型把输入的数据原封不动的存放到数据库中.JSONB类型在存放时把JSON解析成二进制格式. JSON ...

  9. KingbaseES insert all/first 功能介绍

    KingbaseES 内置了对于insert all / first 语法的支持. 一.数据准备 create table t1(product_id number, product_name var ...

  10. KingbaseES ksqlrc文件介绍

    ksqlrc文件作用 ksql在连接到数据库后但在接收正常的命令之前,会尝试读取并执行该文件中的命令,如果加上-X参数,则跳过该文件. 系统级的启动文件是ksqlrc,文件在安装好的KingbaseE ...

随机推荐

  1. centos7搭建postgresql主从(主备)架构

    本篇介绍如何在centos7系统搭建一个postgresql主备集群实现最近的HA(高可用)架构.后续更高级的HA模式都是基于这个最基本的主备搭建. 节点规划 ip 主机名 用途 192.168.18 ...

  2. SpringBoot事务注解@Transactional 事物回滚、手动回滚事物

    处理springboot 下提交事务异常,数据库没有回滚的问题. spring的文档中说道,spring声明式事务管理默认对非检查型异常和运行时异常进行事务回滚,而对检查型异常则不进行回滚操作. 什么 ...

  3. zip压缩模块,tarfile压缩模块,包和模块,format格式化的复习--day17

    1.zipfile模块 import zipfile #导入模块 1.压缩文件 (1)创建压缩包 参数1压缩包名字,参数2以w模式创建,参数3压缩固定写法 zf = zipfile.ZipFile(& ...

  4. yum源配置脚本

    # yum源配置脚本 #!/bin/bash mkdir /etc/yum.repos.d/backup mv /etc/yum.repos.d/*.repo /etc/yum.repos.d/bac ...

  5. ASP.NET Core 微信支付(三)【查询订单 APIV3】

    官方参考资料 查询订单 理论实战 官方提供两种查询订单的方式,一种是根据商户自己生成的订单号查询,一种方式是根据微信生成的订单号查询.而我使用的就是第一种方式. 调用微信支付的查询订单,需要生成签名, ...

  6. 【Azure Spring Cloud】在Azure Spring Apps上看见 App Memory Usage 和 jvm.menory.use 的指标的疑问及OOM

    问题描述 在Azure的Spring Cloud服务 (官名为:Spring Apps)中,在Metrics 页面中查看 App Memory Usage 和 jvm.memory.use,发现两则在 ...

  7. Java 韩顺平老师的课,记的(前6章)笔记

    https://www.bilibili.com/video/BV1fh411y7R8/?p=110&spm_id_from=333.880.my_history.page.click& ...

  8. Educational Codeforces Round 145 (Rated for Div. 2)C. Sum on Subarrays(构造)

    很意思的一道构造题 题意:给一个\(n.k\),让构造长度为n的数组满足,子数组为整数的个数为k个,负数的为\(k-(n+1)* n/2\),每个数的范围为\([-1000,1000]\) 这种构造题 ...

  9. 获取一段时间内,以月/季度为单位,第N天在各个月/季度是几几年几月几号

    /** * 获取一段时间内(可跨年),以季度为单位,第N天在各个季度是几月几号 * @param $sTime 时间戳 * @param $eTime 时间戳 * @param $number 第N天 ...

  10. map 简单梳理【GO 基础】

    〇.map 简介 map 是一种无序的基于 key-value 的数据结构,Go 语言中的 map 是引用类型,必须初始化才能使用. 其中键可以是任何类型,但值必须是可比较的类型(如整数.字符串.布尔 ...