PostgreSQL中使用dblink实现跨库查询的方法
发布时间 - 2026-01-11 01:20:34 点击率:次最近一个sql语句涉及到跨库的表之间的联合查询,故研究学习下。

一开始研究知道了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来做,这样毕竟程序里代码会简单很多。
# PostgreSQL
# 跨库查询
# postgresql使用dblink跨库增删改查的步骤
# Oracle配置dblink访问PostgreSQL的操作方法
# PostgreSQL的dblink扩展模块使用
# 都是
# 来做
# 报错
# 则会
# 博文
# 是在
# 第一个
# 一句
# 只需
# 其他的
# 这个问题
# 要在
# 用了
# 第二个
# 很简单
# 如果没有
# 可以看到
# 却在
# 如图
# 两张
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧
Android仿QQ列表左滑删除操作
Laravel怎么自定义错误页面_Laravel修改404和500页面模板
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
如何撰写建站申请书?关键要点有哪些?
微信小程序 五星评分(包括半颗星评分)实例代码
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
Laravel怎么实现支付功能_Laravel集成支付宝微信支付
如何确保FTP站点访问权限与数据传输安全?
🚀拖拽式CMS建站能否实现高效与个性化并存?
如何在IIS服务器上快速部署高效网站?
打开php文件提示内存不足_怎么调整php内存限制【解决方案】
Laravel怎么解决跨域问题_Laravel配置CORS跨域访问
Laravel如何实现多对多模型关联?(Eloquent教程)
Angular 表单中正确绑定输入值以确保提交与验证正常工作
MySQL查询结果复制到新表的方法(更新、插入)
如何快速选择适合个人网站的云服务器配置?
javascript中数组(Array)对象和字符串(String)对象的常用方法总结
Laravel N+1查询问题如何解决_Eloquent预加载(Eager Loading)优化数据库查询
Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】
Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件
Bootstrap整体框架之JavaScript插件架构
简单实现Android验证码
Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】
php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
昵图网官方站入口 昵图网素材图库官网入口
如何用VPS主机快速搭建个人网站?
详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
长沙企业网站制作哪家好,长沙水业集团官方网站?
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
如何在腾讯云免费申请建站?
香港服务器租用费用高吗?如何避免常见误区?
如何快速重置建站主机并恢复默认配置?
Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践
如何在服务器上配置二级域名建站?
Laravel如何使用Blade组件和插槽?(Component代码示例)
如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】
如何打造高效商业网站?建站目的决定转化率
如何用低价快速搭建高质量网站?
郑州企业网站制作公司,郑州招聘网站有哪些?
如何快速生成ASP一键建站模板并优化安全性?
如何快速建站并高效导出源代码?
ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法
消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工
如何在万网开始建站?分步指南解析

