亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > PostgreSQL > 正文

PostgreSQL中使用dblink實現跨庫查詢的方法

2020-01-31 15:21:37
字體:
來源:轉載
供稿:網友

最近一個sql語句涉及到跨庫的表之間的聯合查詢,故研究學習下。

一開始研究知道了sql語句的寫法,但是執行通過不了,需要先安裝dblink擴展。這些博文里都沒說清楚,感謝網友指點,在windows下只需要在相應的數據庫下執行sql語句“create extension dblink”就ok了。而以上的博文基本上說的都是linux下的操作方法,也因此我走了彎路。

2.下載了PostgreSQL的源代碼,卻不知道語句在哪執行,貌似是在linux下的shell里執行的,我卻在psql和cmd里都試過,都是走過的彎路啊。也嘗試過直接拷貝dblink.sql里的語句運行,卻通不過報錯。

PostgreSQL中如何使用dblink實現跨庫查詢

3.windows下很簡單,一句sql就搞定了“create extension dblink”.
在擴展里可以看到多了一個dblink:

PostgreSQL中如何使用dblink實現跨庫查詢

函數里也相應的有了dblink開頭的一些函數:

PostgreSQL中如何使用dblink實現跨庫查詢

這句sql語句貌似只調用運行了dblink.control文件:

PostgreSQL中如何使用dblink實現跨庫查詢

3.寫sql語句測試下,是否ok。

跨庫查詢,先要建立數據庫連接,才能查詢否則會報錯。

如圖是提示的connection named"unnamed",因為有其他的連接,如果沒有任何連接,則會提示connection not available:

PostgreSQL中如何使用dblink實現跨庫查詢

使用dblink(text,text),第一個參數是連接串,第二個參數是sql語句。執行成功:

PostgreSQL中如何使用dblink實現跨庫查詢

或者使用dblink_connect(text)先建立連接,再用dblink(text)做跨庫查詢:

PostgreSQL中如何使用dblink實現跨庫查詢

查看連接:

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來做,這樣畢竟程序里代碼會簡單很多。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产裸体写真av一区二区| 色噜噜亚洲精品中文字幕| 成人免费观看网址| 欧美成年人在线观看| 最近2019好看的中文字幕免费| 亚洲美女在线看| 欧美激情视频免费观看| 亚洲乱码国产乱码精品精天堂| 日韩av电影免费观看高清| 免费91麻豆精品国产自产在线观看| 国产精品羞羞答答| 国产精品九九九| 91系列在线播放| 4388成人网| 福利一区福利二区微拍刺激| 国产日韩欧美中文| 精品福利在线视频| 国产精品va在线| 久久久久久久影院| 亚洲精品99999| 精品国产91久久久| 亚洲精品一区二区网址| 亚洲欧美国内爽妇网| xxxxx91麻豆| 国产精品成av人在线视午夜片| 亚洲国产精品久久久久秋霞蜜臀| 国产激情999| 欧美富婆性猛交| 精品视频—区二区三区免费| 欧美日韩xxxxx| 久久久久久高潮国产精品视| 欧美一区二区三区四区在线| 欧美午夜激情在线| 欧美日韩国产在线看| 久久精品国产视频| 91中文字幕在线| 97精品国产97久久久久久免费| 欧美性xxxxhd| 亚洲欧美国产精品久久久久久久| 国产精品91免费在线| 日韩欧美有码在线| 国产日韩欧美夫妻视频在线观看| 亚洲偷熟乱区亚洲香蕉av| 亚洲日本aⅴ片在线观看香蕉| 欧美专区福利在线| 国产亚洲精品美女久久久久| 国产欧美精品一区二区三区-老狼| 正在播放国产一区| 日韩精品视频三区| 欧美日本在线视频中文字字幕| 欧美中文字幕视频| 亚洲美女av网站| 国产精品99一区| 日韩av手机在线看| 日韩精品中文字幕有码专区| xxav国产精品美女主播| 亚洲精品免费网站| 日韩在线观看免费全集电视剧网站| 少妇久久久久久| 欧美电影在线观看| 欧美精品videos| 日韩理论片久久| 久久视频在线免费观看| 日韩欧美aⅴ综合网站发布| 欧美一级淫片丝袜脚交| 国产成人精品久久二区二区91| 国产一区香蕉久久| 欧美成人手机在线| 亚洲国产精久久久久久久| 日韩少妇与小伙激情| 欧美一级电影免费在线观看| 国产成人精彩在线视频九色| 亚洲国产毛片完整版| 国产精品视频一区国模私拍| 欧美中文字幕视频| 成人午夜一级二级三级| 亚洲图中文字幕| 欧美成人高清视频| 九九久久久久99精品| 日韩精品在线观看网站| 久久精品中文字幕电影| 美女精品久久久| 亚洲国产欧美自拍| 国产一区二区三区欧美| 大荫蒂欧美视频另类xxxx| 91在线观看免费高清完整版在线观看| 亚洲欧美国产精品久久久久久久| 久久久久久久久久久久久久久久久久av| 久久久亚洲欧洲日产国码aⅴ| 一个人看的www久久| 亚洲影院色在线观看免费| 日韩一区二区精品视频| 欧美另类老女人| 国语自产精品视频在线看抢先版图片| 97国产精品视频人人做人人爱| 欧美激情视频一区| 黄网站色欧美视频| 成人综合网网址| 欧美性xxxxx极品娇小| 成人h视频在线观看播放| 欧美激情精品久久久| 日韩欧美中文字幕在线观看| 精品在线小视频| 这里只有视频精品| 久久久国产视频91| 亚洲剧情一区二区| 成人免费看片视频| 国产欧美婷婷中文| 国产精品自拍偷拍| 九九视频这里只有精品| 91网站免费看| 在线看国产精品| 欧美日韩不卡合集视频| 亚洲夜晚福利在线观看| 久久成人免费视频| 国产v综合ⅴ日韩v欧美大片| 欧美日韩在线第一页| 91久久国产综合久久91精品网站| 国产精品网红福利| 欧美三级免费观看| 日韩中文字幕在线观看| 欧美中文字幕视频在线观看| 91色在线观看| 欧美一级淫片播放口| 一区二区三区www| 国产成人午夜视频网址| 欧美性猛交xxxxx水多| 久热在线中文字幕色999舞| 欧美日韩午夜剧场| 久久亚洲国产精品成人av秋霞| 亚洲精品视频免费| 亚州欧美日韩中文视频| 欧美国产中文字幕| 久久久精品2019中文字幕神马| 欧美激情欧美狂野欧美精品| 久久精品成人一区二区三区| 91精品国产综合久久久久久久久| 国产精品久久综合av爱欲tv| 国产精品极品美女粉嫩高清在线| 91chinesevideo永久地址| 欧美另类99xxxxx| 欧美视频在线观看 亚洲欧| 91在线色戒在线| 久久香蕉国产线看观看av| 欧美一性一乱一交一视频| 欧美激情18p| 亚洲第一视频在线观看| 一本久久综合亚洲鲁鲁| 91精品国产综合久久男男| 国产精品久久久久久中文字| 欧美精品在线免费观看| 不卡伊人av在线播放| 成人精品久久av网站| 久久高清视频免费| 欧美性生交xxxxx久久久| 欧美精品久久久久久久久久| 亚洲欧洲偷拍精品| 精品欧美激情精品一区| 成人黄色av免费在线观看| 久久久久久久国产精品视频| 97免费在线视频| 亚洲第一福利网站| 欧美激情久久久久久| 欧美一级免费看|