《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 業界動態 > 什么是 PostgreSQL 橫向子查詢?

什么是 PostgreSQL 橫向子查詢?

2021-07-25
來源:CSDN

  一般來說,SQL 子查詢只能引用外查詢中的字段,而不能使用同一層級中其他表中的字段。例如:

  -- 錯誤示例

  SELECT d.dept_name,

  t.avg_salary

  FROM department d

  JOIN (SELECT avg(e.salary) AS avg_salary

  FROM employee e

  WHERE e.dept_id = d.dept_id) t;

  SQL 錯誤 [42601]: ERROR: syntax error at end of input

  位置:183

  由于 JOIN 子句中的查詢語句 t 引用了左側 department 表中的字段,因此產生了語法錯誤。

  為了解決以上問題,我們可以使用 PostgreSQL 提供的橫向子查詢(LATERAL subquery)。不過在介紹 LATERAL 關鍵字之前,我們先來回顧一下 SELECT 和 FROM 子句的含義。例如:

  SELECT dept_id, dept_name

  FROM department;

  簡單來說,我們可以將以上查詢看作一個循環處理語句。使用偽代碼實現的以上 SQL 語句如下:

  for dept_id, dept_name in department

  loop

  print dept_id, dept_name

  end loop

  對于 department 中的每一條記錄,都執行 SELECT 語句指定的操作,以上示例簡單的輸出了每行記錄。

  SELECT 就像一個循環語句,而 LATERAL 就像是一個嵌套循環語句,對于左側表中的每行記錄執行一次子查詢操作。例如,通過增加 LATERAL 關鍵字,我們可以修改第一個示例:

  SELECT d.dept_name,

  t.avg_salary

  FROM department d

  CROSS JOIN LATERAL

 ?。⊿ELECT avg(e.salary) AS avg_salary

  FROM employee e

  WHERE e.dept_id = d.dept_id) t;

  dept_name  |avg_salary            |

  -----------+----------------------+

  行政管理部  |    26666.666666666667|

  人力資源部  |13166.6666666666666667|

  財務部      | 9000.0000000000000000|

  研發部      | 7577.7777777777777778|

  銷售部      | 5012.5000000000000000|

  保衛部      |                      |

  CROSS JOIN LATERAL 右側的查詢可以引用左側表中的字段,以上語句為 JOIN 左側的每個部門返回了月薪總和。

  LATERAL 可以幫助我們實現一些有用的分析功能,例如以下查詢返回了每個部門月薪最高的 3 名員工:

  SELECT d.dept_name, t.emp_name, t.salary

  FROM department d

  LEFT JOIN LATERAL

 ?。⊿ELECT emp_name, salary

  FROM employee e

  WHERE e.dept_id = d.dept_id

  ORDER BY salary DESC

  LIMIT 3) t

  ON TRUE;

  dept_name  |emp_name|salary  |

  -----------+--------+--------+

  行政管理部  |劉備     |30000.00|

  行政管理部  |關羽     |26000.00|

  行政管理部  |張飛     |24000.00|

  人力資源部  |諸葛亮   |24000.00|

  人力資源部  |黃忠     | 8000.00|

  人力資源部  |魏延     | 7500.00|

  財務部      |孫尚香   |12000.00|

  財務部      |孫丫鬟   | 6000.00|

  研發部      |趙云     |15000.00|

  研發部      |周倉     | 8000.00|

  研發部      |關興     | 7000.00|

  銷售部      |法正     |10000.00|

  銷售部      |簡雍     | 4800.00|

  銷售部      |孫乾     | 4700.00|

  保衛部      |         |        |

  對于 department 中的每個部門,子查詢 t 最多返回 3 個員工信息。我們使用了 LEFT JOIN LATERAL,從而保證了“保衛部”也會返回一條數據。

  同樣使用偽代碼表示以上查詢語句:

  for d in department

  loop

  for e in employee order by salary desc

  loop

  cnt++

  if cnt <= 3

  then

  return e

  else

  goto next d

  end

  end loop

  end loop

  通過 EXPLIAN 命令查看以上語句的執行計劃:

  EXPLAIN

  SELECT d.dept_name, t.emp_name, t.salary

  FROM department d

  LEFT JOIN LATERAL

  (SELECT emp_name, salary

  FROM employee e

  WHERE e.dept_id = d.dept_id

  ORDER BY salary DESC

  LIMIT 3) t

  ON TRUE;

  QUERY PLAN                                                                                       |

  -------------------------------------------------------------------------------------------------+

  Nested Loop Left Join  (cost=8.174439.35 rows=540 width=250)                                   |

  ->  Seq Scan on department d  (cost=0.0015.40 rows=540 width=122)                            |

  ->  Limit  (cost=8.178.17 rows=1 width=132)                                                  |

  ->  Sort  (cost=8.178.17 rows=1 width=132)                                             |

  Sort Key: e.salary DESC                                                            |

  ->  Index Scan using idx_emp_dept on employee e  (cost=0.148.16 rows=1 width=132)|

  Index Cond: (dept_id = d.dept_id)                                            |

  Nested Loop Left Join 說明 PostgreSQL 使用的就是嵌套循環算法。




電子技術圖片.png

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          欧美亚洲成人网| 欧美一区二区三区在线观看视频| 一本色道久久综合亚洲91| 欧美日本韩国一区| 亚洲欧美中日韩| 欧美激情视频一区二区三区免费| 欧美日韩三级电影在线| 亚洲欧美激情一区二区| 羞羞色国产精品| 欧美久久综合| 欧美黄色日本| 国产女同一区二区| 性欧美xxxx大乳国产app| 久久中文字幕一区| 久久久国产午夜精品| 国产热re99久久6国产精品| 欧美日产一区二区三区在线观看| 亚洲免费激情| 国产精品高清一区二区三区| 国产精品入口66mio| 欧美gay视频激情| 一区二区三区在线观看欧美| 欧美日韩中文字幕日韩欧美| 国产日韩一区| 国产亚洲欧美激情| 国产精品久久久久国产a级| 欧美日韩国产综合视频在线| 激情久久久久久| 欧美二区在线| 国产精品亚洲视频| 一区二区三区精品国产| 国产精品女同互慰在线看| 国产一区二区三区电影在线观看| 欧美日韩国产91| 久久综合一区二区| 欧美日韩一区二区免费在线观看| 亚洲在线播放电影| 久久久之久亚州精品露出| 一区二区久久久久| 狠狠综合久久av一区二区小说| 欧美一区二区三区在线播放| 老鸭窝亚洲一区二区三区| 老司机精品视频网站| 欧美亚洲一区在线| 久久亚洲视频| 国产精品xvideos88| 性欧美18~19sex高清播放| 免费成人黄色av| 久久中文字幕一区二区三区| 欧美亚洲视频一区二区| 欧美日韩精品在线| 国产精品丝袜白浆摸在线| …久久精品99久久香蕉国产| 亚洲精品国产精品国自产在线| 国产精品每日更新| 中文精品一区二区三区| 欧美一级淫片aaaaaaa视频| 国产麻豆精品久久一二三| 欧美在线亚洲一区| 一本高清dvd不卡在线观看| 一区二区不卡在线视频 午夜欧美不卡'| 欧美精品xxxxbbbb| 亚久久调教视频| 国产精品欧美久久久久无广告| 国产精品麻豆成人av电影艾秋| 久久免费少妇高潮久久精品99| 亚洲欧美资源在线| 新67194成人永久网站| 99精品久久| 久久在线免费观看视频| 亚洲一区网站| 在线成人激情视频| 国产精品美女午夜av| 午夜在线视频一区二区区别| 日韩一区二区免费看| 久久av一区二区三区漫画| 亚洲天堂av电影| 一本一本久久a久久精品综合麻豆| 欧美在线视频观看免费网站| 欧美影片第一页| 亚洲一区二区三区高清| 亚洲欧美日韩另类| 久久国产主播精品| 欧美亚州韩日在线看免费版国语版| 美女诱惑黄网站一区| 欧美国产日韩二区| 欧美高清一区| 欧美一区亚洲二区| 麻豆av福利av久久av| 久久香蕉精品| 亚洲视频一区二区免费在线观看| 韩国av一区二区| 亚洲一区二区三区高清不卡| 在线精品视频在线观看高清| 亚洲精品黄色| 欧美激情一区在线| 亚洲激情图片小说视频| 精品动漫3d一区二区三区| 91久久精品国产91性色tv| 久久香蕉国产线看观看av| 欧美三区美女| 久久精品一区二区国产| 国产亚洲欧洲一区高清在线观看| 亚洲激情另类| 欧美私人网站| 欧美国产视频一区二区| 欧美激情精品久久久| 国产专区欧美专区| 国产一区二区三区黄视频| 久久精品青青大伊人av| 久久精品国产99| 欧美了一区在线观看| 免费在线视频一区| 1000精品久久久久久久久| 欧美视频日韩视频在线观看| 久久久久久欧美| 欧美日本国产一区| 亚洲激情av在线| 久久久久成人网| 亚洲精品中文字幕女同| 久久综合九色欧美综合狠狠| 亚洲一区二区三区国产| 99re成人精品视频| 久久久噜噜噜久噜久久| 亚洲日韩欧美视频一区| 久久黄色级2电影| 在线精品视频一区二区| 欧美国产在线视频| 亚洲精品乱码久久久久久蜜桃麻豆| 国产精品理论片在线观看| 中文高清一区| 亚洲一区二区三区高清不卡| 亚洲自啪免费| 亚洲免费一级电影| 日韩一级在线观看| 亚洲婷婷国产精品电影人久久| 久久精品99国产精品酒店日本| 一区二区三区精品视频在线观看| 欧美日韩综合不卡| 欧美人与性动交cc0o| 亚洲欧美日韩直播| 伊人成年综合电影网| 国产精品v亚洲精品v日韩精品| 欧美日韩中文字幕| 欧美成人日本| 欧美在线视频一区二区| 国产一区二区三区久久悠悠色av| 亚洲影视九九影院在线观看| 欧美午夜性色大片在线观看| 欧美调教视频| 性做久久久久久久免费看| 国产一区二区成人久久免费影院| 久久久久久一区二区三区| 久久久精品动漫| 国产精品激情电影| 久久久91精品国产一区二区三区| 欧美午夜视频在线观看| 久久国产一区二区三区| 久久亚洲精品视频| 亚洲欧美日韩在线观看a三区| 亚洲九九爱视频| 久久免费视频这里只有精品| 一区二区三区四区国产| 国产日产高清欧美一区二区三区| 欧美激情国产高清| 亚洲一区三区在线观看| 国产精品自拍三区| 亚洲欧美视频在线观看| 国产精品swag| 亚洲第一区中文99精品| 欧美性色视频在线| 亚洲欧美在线aaa| 国产精品三级久久久久久电影| 午夜视频在线观看一区| 国产精品久久毛片a| 老司机亚洲精品| 美国成人毛片| 国产精品久久久一本精品| 久久久久久久91| 国产精品vip| 亚洲人成在线播放| 男女激情久久| 国产精品国产三级国产普通话99| 日韩一级片网址| 在线看国产一区| 久久九九国产精品怡红院| 国产欧美三级| 永久免费视频成人| 欧美视频一区在线观看| 欧美成人伊人久久综合网| 亚洲欧洲日本mm| 国产麻豆9l精品三级站| 久久激情一区| 一区二区三区视频在线| 欧美自拍丝袜亚洲| 亚洲午夜电影网| 性视频1819p久久| 国产一区高清视频| 欧美日产国产成人免费图片| 黄色日韩精品| 可以看av的网站久久看| 国产一区 二区 三区一级| 国产欧美1区2区3区| 国产欧美日韩亚州综合| 亚洲第一中文字幕在线观看| 亚洲精品中文字幕在线观看| 亚洲欧美日韩精品久久久久| 久久精品91久久久久久再现| 欧美日韩国产综合视频在线观看中文| 日韩一区二区精品葵司在线| 欧美综合激情网| 久久激情网站| 黄色亚洲大片免费在线观看| 国产欧美日韩亚洲一区二区三区| 国产精品美女999| 9i看片成人免费高清| 亚洲高清一区二区三区| 在线视频中文亚洲| 午夜激情一区| 久久久久久香蕉网| 亚洲中无吗在线| 亚洲精品国产精品国自产观看| 中日韩美女免费视频网址在线观看| 午夜精品在线观看| 久久九九免费视频| 一区二区三区欧美| 一区二区视频免费完整版观看| 久久综合伊人77777| 国产欧美日韩一区二区三区在线| 欧美在线视频导航| 久久精品国产91精品亚洲| 亚洲欧美区自拍先锋| 欧美一区二区三区免费视频| 亚洲国内高清视频| 欧美/亚洲一区| 欧美成人一品| 夜夜嗨av一区二区三区四区| 精品成人一区| 亚洲美女一区| 久久精品亚洲一区二区三区浴池| 亚洲欧美三级在线| 亚洲综合精品自拍| 欧美粗暴jizz性欧美20| 欧美日在线观看| 久久久综合免费视频| 欧美在线日韩| 中文精品视频一区二区在线观看| 久久精品天堂| 日韩午夜av电影| 国产精品成人免费精品自在线观看| 亚洲永久免费av| 欧美视频亚洲视频| 亚洲欧美日韩一区在线| 欧美视频日韩视频| 亚洲免费人成在线视频观看| 亚洲激情电影中文字幕| 亚洲精品在线一区二区| 国产精品成人一区二区网站软件| 欧美日韩国产三区| 这里只有视频精品| 欧美日韩伦理在线| 久久在线播放| 欧美在线|欧美| 91久久久精品| 国产精品一区视频网站| 性欧美video另类hd性玩具| 亚洲欧洲精品一区二区精品久久久| 亚洲茄子视频| 国语自产精品视频在线看| 亚洲电影第1页| 国产精品午夜春色av| 久久亚洲电影| 91久久国产精品91久久性色| 欧美亚洲尤物久久| 国产一区二区精品久久99| 久久久久综合一区二区三区| 欧美日韩在线播| 欧美日本一区二区高清播放视频| 欧美图区在线视频| 欧美剧在线观看| 免费成人高清| 国产精品久久久久久亚洲毛片| 99这里只有久久精品视频| 亚洲国产成人在线| 国产精品久久久久久久久久久久久| 国产精品vip| 国产精品www色诱视频| 欧美日韩精品在线观看| 一区二区三区欧美日韩| 亚洲精品久久| 欧美高清在线播放| 亚洲精选国产| 亚洲高清在线播放| 亚洲第一中文字幕在线观看| 亚洲曰本av电影| 久久精品国产久精国产一老狼| 欧美成人精精品一区二区频| 亚洲欧美美女| 99re热这里只有精品免费视频| 99av国产精品欲麻豆| 欧美a级在线| 国产一区视频在线观看免费| 影音先锋国产精品| 亚洲精品日产精品乱码不卡| 狠狠色综合网站久久久久久久| 国产精品卡一卡二| 这里只有精品视频| 午夜精品久久久久久久99黑人| 国产精品一卡二| 一区二区欧美在线| 亚洲欧美日本日韩| 国产日韩在线看片| 国产精品入口夜色视频大尺度| 猫咪成人在线观看| 在线观看欧美日韩国产| 亚洲欧洲精品一区| 欧美日韩一区在线| 在线精品视频在线观看高清| 欧美一区二区播放| 欧美激情精品久久久六区热门| 欧美视频二区36p| 亚洲国产清纯| 裸体丰满少妇做受久久99精品| 国产伦精品一区二区三区免费| 久久久精品国产99久久精品芒果| 欧美激情精品| 欧美高清在线| 国产精品国色综合久久|