溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

PostgreSQL中怎么利用dblink實(shí)現(xiàn)跨庫(kù)查詢(xún)

發(fā)布時(shí)間:2021-07-26 15:08:59 來(lái)源:億速云 閱讀:1578 作者:Leah 欄目:數(shù)據(jù)庫(kù)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)PostgreSQL中怎么利用dblink實(shí)現(xiàn)跨庫(kù)查詢(xún),文章內(nèi)容豐富且以專(zhuān)業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

一開(kāi)始研究知道了sql語(yǔ)句的寫(xiě)法,但是執(zhí)行通過(guò)不了,需要先安裝dblink擴(kuò)展。這些博文里都沒(méi)說(shuō)清楚,感謝網(wǎng)友指點(diǎn),在windows下只需要在相應(yīng)的數(shù)據(jù)庫(kù)下執(zhí)行sql語(yǔ)句“create  extension dblink”就ok了。而以上的博文基本上說(shuō)的都是linux下的操作方法,也因此我走了彎路。

2.下載了PostgreSQL的源代碼,卻不知道語(yǔ)句在哪執(zhí)行,貌似是在linux下的shell里執(zhí)行的,我卻在psql和cmd里都試過(guò),都是走過(guò)的彎路啊。也嘗試過(guò)直接拷貝dblink.sql里的語(yǔ)句運(yùn)行,卻通不過(guò)報(bào)錯(cuò)。

PostgreSQL中怎么利用dblink實(shí)現(xiàn)跨庫(kù)查詢(xún)

3.windows下很簡(jiǎn)單,一句sql就搞定了“create extension dblink”.

在擴(kuò)展里可以看到多了一個(gè)dblink:

PostgreSQL中怎么利用dblink實(shí)現(xiàn)跨庫(kù)查詢(xún)

函數(shù)里也相應(yīng)的有了dblink開(kāi)頭的一些函數(shù):

PostgreSQL中怎么利用dblink實(shí)現(xiàn)跨庫(kù)查詢(xún)

這句sql語(yǔ)句貌似只調(diào)用運(yùn)行了dblink.control文件:

PostgreSQL中怎么利用dblink實(shí)現(xiàn)跨庫(kù)查詢(xún)

3.寫(xiě)sql語(yǔ)句測(cè)試下,是否ok。

跨庫(kù)查詢(xún),先要建立數(shù)據(jù)庫(kù)連接,才能查詢(xún)否則會(huì)報(bào)錯(cuò)。

如圖是提示的connection named"unnamed",因?yàn)橛衅渌倪B接,如果沒(méi)有任何連接,則會(huì)提示connection not  available:

PostgreSQL中怎么利用dblink實(shí)現(xiàn)跨庫(kù)查詢(xún)

使用dblink(text,text),***個(gè)參數(shù)是連接串,第二個(gè)參數(shù)是sql語(yǔ)句。執(zhí)行成功:

PostgreSQL中怎么利用dblink實(shí)現(xiàn)跨庫(kù)查詢(xún)

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

PostgreSQL中怎么利用dblink實(shí)現(xiàn)跨庫(kù)查詢(xún)

查看連接:

select dblink_get_connections()

斷開(kāi)所有連接:

select dblink_disconnect()

斷開(kāi)指定名稱(chēng)的連接:

select dblink_disconnect('test')

如之前建立過(guò)名為‘test'的連接:

select dblink_connect('test','host=localhost dbname=cbe_sta user=postgres password=lifc126820');

則會(huì)提示斷開(kāi)成功。

4.***,我自己需要的sql語(yǔ)句也ok了,在同一個(gè)服務(wù)器上的兩個(gè)數(shù)據(jù)庫(kù)3張表的聯(lián)合查詢(xún),先建立連接再做查詢(xún):

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語(yǔ)句會(huì)報(bào)錯(cuò)說(shuō)無(wú)法建立連接:

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

上述就是小編為大家分享的PostgreSQL中怎么利用dblink實(shí)現(xiàn)跨庫(kù)查詢(xún)了,如果剛好有類(lèi)似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI