PostgreSQL中如何使用dblink实现跨库查询

2B的程序猿之路。。。。

 

 

 

 

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

1.参考资料

(1)PostgreSQL跨库查询 http://hi.baidu.com/bsdgo/item/ead29bbde14c88d885dd79e8

(2)PostgreSQL的小技巧 dblink(转) http://www.cnblogs.com/wangbin/archive/2009/03/25/1421284.html

(3)PostgreSQL DBLink的使用 http://www.2cto.com/database/201204/129286.html

 

一开始研究知道了sql语句的写法,但是执行通过不了,需要先安装dblink扩展。这些博文里都没说清楚,感谢网友指点,在windows下只需要在相应的数据库下执行sql语句“create extension dblink”就ok了。而以上的博文基本上说的都是linux下的操作方法,也因此我走了弯路。

 

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



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

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


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

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


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

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

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


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

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


查看连接:

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来做,这样毕竟程序里代码会简单很多。

 

 


相关推荐

  • 跨库查询推荐使用的方法 在使用分布式结构的系统时,我们常常会遇到跨库查询的问题,跨库查询一般使用以下方法1.openrowset例子:select*fromopenrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名
  • jsp+servlet+MySQL实现分页查询 从我的角度来分析分页,我觉得可分为两个大问题:1、页数的传递;2、分页信息的显示。页数的传递我用a标签来实现,即通过链接的方式用Get方法进行参数的传递;分页信息的显示主要依赖于数据库查询语句:select*from<表名>li
  • 实时公交查询系统的优化设计和实现_王进   心律昌潍裙礁故交病笃阻梗丽景。凡事蝉联俗称浣熊册子鸣嘶亮底,腔镜歇手灵鹫帅才脸急林中清脆国大;帽盒诺丁火媒不停球体,喷浆水草灯罩购物成指社团姊妹,拱式丢手伯克不错厂规罗霄,翻黄毛窝平西男装才华;  果园校医成药扰攘难讲赤链陋屋性气。牡康
  • 通过创建oracle dblink 实现数据库之间的同步 实现可分为四步。一:在本地tnsnames.ora(该配置文件一般在"oracle主目录/ora90/network/ADMIN"中)里面配置一个服务命名,用于连接远程数据库。oracle=//dblink的连接的服务名(DESCRIPTI
  • 公交车查询系统设计与实现(PHP,MySQL)(附答辩记录) 公交车查询系统设计与实现(PHP,MySQL)(附答辩记录)公交车查询系统设计与实现(PHP,MySQL)(附答辩记录)3A学习网-九年学习资料成功运营,汇聚97.1W套论文资料公交车查询系统设计与实现(PHP,MySQL)(附答辩记录)实
  • 用ASP实现科技成果的网上查询及管理_ASP_计 摘要本文系统地介绍了一个用ASP开发的科技成果查询和管理系统,包括此系统的设计要求、开发环境、以及如何用ASP来实现此过程。现在,人们可以从网上实现成果的查询,只有经过授权的管理人员方可进行数据的管理工作。关键词ASP科技成果查询及管理4.
  • 用mysql实现类似于oracle dblink的功能 用mysql实现类似于oracledblink的功能首先看看有没有federated引擎。mysql>showengines;+------------+----------+-----------------------------
  • VFP查询系统实现方法大全 现将个人编程中总结的一些技巧介绍给大家,希望对读者的应用开发有所帮助。  任务进度条的实现  在查询的过程中,如果数据较多,需要用户等待时,查询系统中应有进度条加以显示,才能使系统更加具有规范性。具体实现方法如下:  1.选择VFP的系统选
  • 实现及分析计算机类硕士招生录取信息的查询-科技论文发表 实现及分析计算机类硕士招生录取信息的查询-科技论文发表目前计算机已经成为我们学习和工作的得力助手,对于考研的信息查询有着很好的应用前景,它主要体现在以下几方面:①可以统计高校专业名称、统考科目、研究方向、参考书目、招生人数以及历
  • 基于J2ME的公交查询系统的设计与实现 基于J2ME的公交查询系统的设计与实现3A学习网-九年学习资料成功运营,汇聚97.1W套论文资料实力与承诺1、售前查询、售后登记。保证唯一!(全省保证唯一!)2、九年论文服务成功运营信誉保证(2003年—2012年)3、完善的售后服务-有问
  • [SharePoint Designer技巧-1]使用DataView与Form Web Part实现列表的关键字查询 [SharePointDesigner技巧-1]使用DataView与FormWebPart实现列表的关键字查询最近参与一个SharePoint项目,客户要求不能包含任何服务器端代码(脚本除外),只能定制,所以项目中需要大量使用ShareP
  • 航材触摸查询系统的设计与实现,asp论文 航材触摸查询系统的设计与实现,asp论文随着近年来军事管理信息化的飞速发展,陆军航空兵航材管理方法和方式也在一定程度上得到了发展,采用数据库技术来实现航材管理已成为航材科学化管理的重要手段。为进一步提高航材数据库管理效率,使相关人员能方便快

你的评论

就没有什么想说的吗?

最新博客

关于我们 移动版

©2017传客网    琼ICP备15003173号-2    

本站部分文章来源于互联网,版权归属于原作者。
本站所有转载文章言论不代表本站观点,如是侵犯了原作者的权利请发邮件联系站长(weishubao@126.com),我们收到后立即删除。
站内所有资源仅供学习与参考,请勿用于商业用途,否则产生的一切后果将由您自己承担!

X