注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

星期五

明天不上班

 
 
 

日志

 
 
关于我

一个特立独行的Java程序员,比较宅,上上网,写博客,听音乐,看电影。

网易考拉推荐

使用postgres_dblink实现跨数据访问  

2012-06-13 21:47:06|  分类: Postgresql |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
关于postgres_dblink 实现跨数据库访问,不管是local还是remote 
环境:Ubuntu12.04,Postgresql9.1
1.安装
sudo apt-get install postgresql-contrib-9.1
/usr/share/postgresql/9.1/extension/dblink--1.0.sql

postgres@hjzheng-ThinkPad-T520:/usr$ psql -U postgres -d postgres -f /usr/share/postgresql/9.1/extension/dblink--1.0.sql
Use "CREATE EXTENSION dblink" to load this file.
使用superuser postgres执行 "CREATE EXTENSION dblink" 命令

2.使用dblink
举例,在postgres中访问mydb的mytable数据表 由于两个数据库都是本地,所以host,port参数省略
SELECT *
FROM dblink('dbname=mydb user=postgres password=postgres','SELECT name FROM mytable')
AS test(name varchar(128));

参考资料:
http://www.postgresonline.com/journal/archives/44-Using-DbLink-to-access-other-PostgreSQL-Databases-and-Servers.html
http://packages.ubuntu.com/oneiric/amd64/postgresql-contrib-9.1/filelist
其他函数使用

--建立持久连接 , 连接Name是 myConnect 
SELECT dblink_connect('myConnect','dbname=mydb user=postgres password=postgres');

--跨数据库查询
SELECT * FROM dblink('myConnect','SELECT name FROM mytable')
    AS test(name varchar(128));

--断开连接
select dblink_disconnect('myConnect')

参考资料:
  评论这张
 
阅读(1361)| 评论(0)
推荐

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017