lamda postgresql mysql 联合查询_PostgreSQL中如何使用dblink实现跨库查询

转自:http://blog.sina.com.cn/s/blog_673c98be0101gv43.html

最近一个sql语句涉及到跨库的表之间的联合查询,故研究学习下。

1.参考资料

一开始研究知道了sql语句的写法,但是执行通过不了,需要先安装dblink扩展。这些博文里都没说清楚,感谢网友指点,在windows下只需要在相应的数据库下执行sql语句“create

extension dblink”就ok了。而以上的博文基本上说的都是linux下的操作方法,也因此我走了弯路。

2.下载了PostgreSQL的源代码,却不知道语句在哪执行,貌似是在linux下的shell里执行的,我却在psql和cmd里都试过,都是走过的弯路啊。也尝试过直接拷贝dblink.sql里的语句运行,却通不过报错。

a9b6492994aa305fb9650c805d97c09c.png

3.windows下很简单,一句sql就搞定了“create extension dblink”.

在扩展里可以看到多了一个dblink:

bdd102868699039d21ea71bbc337707f.png

函数里也相应的有了dblink开头的一些函数:

601f64a12e249fa991575a34d72a09df.png

这句sql语句貌似只调用运行了dblink.control文件:

9981651d5e4b4ac8557b3a3f23aeccb7.png

3.写sql语句测试下,是否ok。

跨库查询,先要建立数据库连接,才能查询否则会报错。

如图是提示的connection named

"unnamed",因为有其他的连接,如果没有任何连接,则会提示connection not available:

da94f6013800a0290f83ee243b08b350.png

使用dblink(text,text),第一个参数是连接串,第二个参数是sql语句。执行成功:

2f4032a7acc930b50300bb5b1f62f963.png

或者使用dblink_connect(text)先建立连接,再用dblink(text)做跨库查询:

eff1b1963f1214c9b47fa06fd712657a.png

查看连接:

select dblink_get_connections()

断开所有连接:

select dblink_disconnect()

断开指定名称的连接:

select dblink_disconnect('test')

如之前建立过名为‘test’的连接:

select dblink_connect('test','host=localhost dbname=cbe_sta

user=postgres password=lifc126820');

则会提示断开成功。

4.最后,我自己需要的sql语句也ok了,在同一个服务器上的两个数据库3张表的联合查询,先建立连接再做查询:

select dblink_connect('host=localhost dbname=cbe_userdata

user=postgres password=lifc126820');

select A.id,A.code as

poicode,A.cname,A.geo,A.x,A.y,A.s01,A.s02,A.s03,A.updatetime,A.tbcode,D.code,D.data,D.value,D.cname

as colname,D.ifdata,D.sort from tb_test_poi A inner join ((select *

from dblink('select poicode,code,data,value from tb_test_data_poi')

as T1(poicode character varying(50),code character varying(50),data

double precision,value character varying(500))) B inner join

(select * from dblink('select cname,code as code1,ifdata,sort from

tb_test_index_poi') as T2(cname character varying(200),code1

character varying(50),ifdata character varying(5),sort character

varying(50))) C on B.code=C.code1) D on A.code=D.poicode;

如果做成视图也行,这里就需要用dblink(text,text),如果直接用上面的sql语句会报错说无法建立连接:

CREATE OR REPLACE VIEW vw_test_poi AS

SELECT a.id, a.code AS poicode, a.cname, a.geo,

a.x, a.y, a.s01, a.s02, a.s03,

a.updatetime, a.tbcode, d.code, d.data, d.value, d.cname AS

colname,

d.ifdata,

d.sort

FROM tb_test_poi a

JOIN (( SELECT t1.poicode,

t1.code, t1.data, t1.value

FROM dblink('host=localhost dbname=cbe_userdata user=postgres

password=lifc126820'::text, 'select poicode,code,data,value from

tb_test_data_poi'::text) t1(poicode character varying(50), code

character varying(50), data double precision, value character

varying(500))) b

JOIN ( SELECT t2.cname,

t2.code1, t2.ifdata, t2.sort

FROM dblink('host=localhost dbname=cbe_userdata user=postgres

password=lifc126820'::text, 'select cname,code as code1,ifdata,sort

from tb_test_index_poi'::text) t2(cname character varying(200),

code1 character varying(50), ifdata character varying(5), sort

character varying(50))) c ON b.code::text = c.code1::text) d ON

a.code::text = d.poicode::text;

我发觉执行效率有点慢啊,查出来的数据是1万多条,用了2秒多。目前我的程序里并没有用dblink来做,因为输入参数可以先单独查一张表即可,然后给另

外两张表的信息关联查询上ok了,所以我分两步来做了,解决了这个问题。具体效率未深入对比,如果后期需要调整,可以考虑用dblink来做,这样毕竟程

序里代码会简单很多。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值