KingbaseES DBLink 介绍
2024-10-20 21:12:19
DBLink 扩展插件功能与 Kingbase_FDW 类似,用于远程访问KingbaseES 数据库。相比于Kingbase_FDW,DBLink 功能更强大,可以执行DML,还可以通过 begin ... end 完成事务操作。以下介绍dblink扩展的使用。
一、测试环境
本地数据库 | 远程数据库 | |
IP | 192.168.237.42 | 192.168.237.43 |
用户 | user_local | user_remote |
1、本地数据库创建用户
test=# create role user_local with login;
CREATE ROLE
test=# alter role user_local with password 'user_local';
ALTER ROLE
test=# create schema user_local authorization user_local;
CREATE SCHEMA
2、远程数据库创建用户与测试表
test=# create role user_remote with login;
CREATE ROLE
test=# alter role user_remote with password 'user_remote';
ALTER ROLE
test=# create schema user_remote authorization user_remote;
CREATE SCHEMA test=# \c test user_remote
You are now connected to database "test" as user "user_remote".
test=> create table t1(id integer,name char(9));
CREATE TABLE
test=> insert into t1 values(1,'a');
INSERT 0 1
test=> insert into t1 values(2,'b');
INSERT 0 1
二、创建扩展插件
1、创建扩展
test=# create extension dblink;
CREATE EXTENSION 创建后,pg_foreign_data_wrapper 会新增一条记录。
test=# select * from pg_foreign_data_wrapper where fdwname='dblink_fdw';
oid | fdwname | fdwowner | fdwhandler | fdwvalidator | fdwacl | fdwoptions
-------+------------+----------+------------+--------------+--------+------------
16466 | dblink_fdw | 10 | 0 | 16465 | |
2、创建Server
create server dblink_to43 foreign data wrapper dblink_fdw options (hostaddr '192.168.237.43' , dbname 'test'); test=# select * from pg_foreign_server where srvname='dblink_to43';
oid | srvname | srvowner | srvfdw | srvtype | srvversion | srvacl | srvoptions
-------+-------------+----------+--------+---------+------------+--------+---------------------------------------
24693 | dblink_to43 | 10 | 24692 | | | | {hostaddr=192.168.237.43,dbname=test}
(1 row) grant usage on foreign server dblink_to43 to user_local;
3、创建用户映射
create user mapping for user_local server dblink_to43 options (user 'user_remote' , password 'user_remote'); test=# select * from pg_user_mappings;
umid | srvid | srvname | umuser | usename | umoptions
-------+-------+-------------+--------+------------+-----------------------------------------
24694 | 24693 | dblink_to43 | 24645 | user_local | {user=user_remote,password=user_remote}
(1 row)
三、测试数据库访问
1、dblink 连接
test=> \c test user_local
You are now connected to database "test" as user "user_local".
test=> select dblink_connect('conn01','dblink_to43') ;
dblink_connect
----------------
OK
(1 row) test=> select * from sys_database_link;
oid | lnkname | lnknamespace | lnkuser | lnkowner | lnkserver | dbtype | lnkoptions | lnkcreated
-----+---------+--------------+---------+----------+-----------+--------+------------+------------
(0 rows) test=> select * from all_db_links;
owner | db_link | username | host | created
-------+---------+----------+------+---------
(0 rows)
以dblink_connect 方式连接,采用的是长连接,直到显示关闭,或者数据库会话结束。
Note:dblink 信息在 sys_database_link 是看不到的,sys_database_link 是配合 kdb_database_link 插件使用。
2、数据访问
test=> select * from dblink('conn01','select * from t1');
id | name
----+-----------
1 | a
2 | b
(2 rows) test=> select dblink_exec('conn01','insert into t1 values(1,''a'')');
dblink_exec
-------------
INSERT 0 1
(1 row) test=> select * from dblink_exec('conn01','insert into t1 values(1,''a'')');
dblink_exec
-------------
INSERT 0 1
(1 row)
3、事务操作
test=> SELECT dblink_exec('conn01', 'BEGIN');
dblink_exec
-------------
BEGIN
(1 row) test=> select dblink_exec('conn01','insert into t1 values(1,''a'')');
dblink_exec
-------------
INSERT 0 1
(1 row) test=> SELECT dblink_exec('conn01', 'COMMIT');
dblink_exec
-------------
COMMIT
(1 row)
4、断开连接
test=> SELECT dblink_disconnect('conn01');
dblink_disconnect
-------------------
OK
(1 row)
四、其他注意点
以上例子的是用dblink_connect 创建连接,是长连接。也可以在执行SQL的同时创建连接:
test=> select * from dblink('dbname=test host=192.168.237.43 port=54321 user=user_remote password=user_remote','select * from t1');
还有,dblink 实际是数据库的连接,前提是目标端的 sys_hba.conf 必须支持连接。
五、DBLINK缺点
(1)每次连接时,都要使用<wiz_tmp_highlight_tag class="cm-searching">dblink_connect建立连接才能查询,对用户来说并不是透明的。
(2)每次查询一张表都要在sql中命名字段和类型,或者配置视图把sql“封装”起来。逐个封装视图,也是一件很麻烦的事。
(3)dblink在运行数据量大的sql时容易丢失远程连接,导致查询或者更新失败
最新文章
- 测试一下StringBuffer和StringBuilder及字面常量拼接三种字符串的效率
- 详细解读DialogFragment
- Java 零基础之作业小练习
- sql 错误提示
- [codility]CountDiv
- php的redis 操作类,适用于单台或多台、多组redis服务器操作
- hdoj 3572 Task Schedule【建立超级源点超级汇点】
- 在 React 中使用 JSX 的好处
- 致IT同仁 — IT人士常犯的17个职场错误
- Android简易实战教程--第二十七话《自定义View入门案例之开关按钮详细分析》
- Easy RM to MP3 Converter栈溢出定位及漏洞利用
- Python--Virtualenv简明教程(转载https://www.jianshu.com/p/08c657bd34f1)
- 关于bug的一些思考
- this指向问题,只提供案例,不做任何分析
- 转 node.js和 android中java加密解密一致性问题;
- flask框架--cookie,session
- des,原理待续
- 更改paramiko 源码 记录命令实现堡垒机功能
- SQL 文件以及文件组
- CakePHP Model中( 获取Session)使用Component的方法
热门文章
- 【实时数仓】Day06-数据可视化接口:接口介绍、Sugar大屏、成交金额、不同维度交易额(品牌、品类、商品spu)、分省的热力图 、新老顾客流量统计、字符云
- .NET性能优化-ArrayPool同时复用数组和对象
- OpenVINO计算机视觉模型加速
- [seaborn] seaborn学习笔记7-常用参数调整Adjustment of Common Parameters
- [编程基础] C++多线程入门2-连接和分离线程
- HttpServletRequest获取参数和文件
- 基于 VScode 搭建 Qt 运行环境
- py教学之元组
- Flutter2.X学习之路--调试页面布局好用的办法
- SOFAJRaft源码阅读(伍)-初识RheaKV