這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)PostgreSQL中怎么利用dblink實現(xiàn)跨庫查詢,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:空間域名、網(wǎng)絡(luò)空間、營銷軟件、網(wǎng)站建設(shè)、拉孜網(wǎng)站維護、網(wǎng)站推廣。
一開始研究知道了sql語句的寫法,但是執(zhí)行通過不了,需要先安裝dblink擴展。這些博文里都沒說清楚,感謝網(wǎng)友指點,在windows下只需要在相應(yīng)的數(shù)據(jù)庫下執(zhí)行sql語句“create extension dblink”就ok了。而以上的博文基本上說的都是linux下的操作方法,也因此我走了彎路。
2.下載了PostgreSQL的源代碼,卻不知道語句在哪執(zhí)行,貌似是在linux下的shell里執(zhí)行的,我卻在psql和cmd里都試過,都是走過的彎路啊。也嘗試過直接拷貝dblink.sql里的語句運行,卻通不過報錯。
3.windows下很簡單,一句sql就搞定了“create extension dblink”.
在擴展里可以看到多了一個dblink:
函數(shù)里也相應(yīng)的有了dblink開頭的一些函數(shù):
這句sql語句貌似只調(diào)用運行了dblink.control文件:
3.寫sql語句測試下,是否ok。
跨庫查詢,先要建立數(shù)據(jù)庫連接,才能查詢否則會報錯。
如圖是提示的connection named"unnamed",因為有其他的連接,如果沒有任何連接,則會提示connection not available:
使用dblink(text,text),***個參數(shù)是連接串,第二個參數(shù)是sql語句。執(zhí)行成功:
或者使用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了,在同一個服務(wù)器上的兩個數(shù)據(jù)庫3張表的聯(liá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語句會報錯說無法建立連接:
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實現(xiàn)跨庫查詢了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
分享文章:PostgreSQL中怎么利用dblink實現(xiàn)跨庫查詢
文章來源:http://chinadenli.net/article12/gisegc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、微信小程序、外貿(mào)建站、小程序開發(fā)、企業(yè)網(wǎng)站制作、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)