好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PostgreSQL中使用dblink實現跨庫查詢的方法

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

熱門標簽:外呼線路資源屬于電信業務嗎 智能外呼系統官網 長沙電銷外呼防封卡是什么 河南電話外呼系統招商 呼和浩特外呼系統原理是什么 crm外呼系統聯系方式 內蒙古營銷智能外呼系統哪個好 小裙科技電銷機器人怎樣 青白江400企業電話申請

最近一個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樹形結構的遞歸查詢示例
  • Postgresql查詢效率計算初探
  • pgsql查詢優化之模糊查詢實例詳解

標簽:楚雄 菏澤 白山 安順 池州 黃石 舟山 呼倫貝爾

巨人網絡通訊聲明:本文標題《PostgreSQL中使用dblink實現跨庫查詢的方法》,本文關鍵詞  PostgreSQL,中,使用,dblink,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL中使用dblink實現跨庫查詢的方法》相關的同類信息!
  • 本頁收集關于PostgreSQL中使用dblink實現跨庫查詢的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 精品人妻无码一区二区三区蜜臀| 108种啪姿势大全动态图| 又黄又湿国产大片| 牛鞭进入女人下身视频| 亚偷熟乱区视频在线观看| 玉梅在厨房里被躁到高潮视频| yy6080韩国日本三理论免费| 顶臀精品视频www网站| 又大又粗又爽毛片毛绒| 久久香蕉国产在产线看观看| 多男用舌头伺候一女NP文 | 曰韩高清理论片| 国产精品免费视频一区| 欧亚专线欧洲在线| 十八禁在线观看完整版| 波多野结衣同性系列260| 好男人午夜www视频在线观看| 色狠狠一区二区三区香蕉| 国产在线拍偷自揄拍精品| 免费三级电影网| 欧美xxxx极品流血| 色姑娘天天操| 久久99精品久久久久久青青91| 色姝姝av爽爽影院| 出差被夫の上司连续高潮正在播放| x8x8x8女性性爽免费视频在线观看| 国内大量揄拍情侣品视频| 国家一级毛片| 女性干涩没水怎样调理| 在线听荤肉爽文有声小说软件| 18japonensis日本欧美18| 国产精品怡红院在线观看| japanese东莞 国产| 91大神半推半就宾馆对白Av| 久久久久国产成人精品亚洲午夜 | 喜爱夜蒲电影| 自愉自愉产区二十四区| 给清水文男主们开荤nph| 亚洲一区精品视频在线| 宝贝 夹住 乖,含着,吸出来| 沟厕大白屁股国产盗摄|