《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 業界動態 > 什么是 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

  (SELECT 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

  (SELECT 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。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
夜夜嗨av一区二区三区网站四季av| 新67194成人永久网站| 日韩视频亚洲视频| 亚洲国产日韩欧美在线图片| 国内久久精品| 国产视频精品xxxx| 国产免费成人在线视频| 国产精品久久久久久久app| 欧美日韩精品综合在线| 欧美激情一区在线观看| 蜜臀av国产精品久久久久| 久久婷婷一区| 久久视频精品在线| 久久综合网hezyo| 久久综合九色99| 免费在线观看成人av| 免费人成网站在线观看欧美高清| 久久午夜色播影院免费高清| 久久亚洲私人国产精品va| 久久亚洲私人国产精品va| 毛片基地黄久久久久久天堂 | 亚洲一区二区精品| 亚洲一线二线三线久久久| 亚洲永久免费av| 午夜精品www| 欧美在线观看日本一区| 久久久久国产精品厨房| 久久一二三国产| 欧美精品久久久久久久| 欧美日韩国产二区| 国产精品盗摄一区二区三区| 国产精品美女久久久久aⅴ国产馆| 国产乱码精品一区二区三区av| 国产一区二区欧美| 在线成人性视频| 亚洲精品综合在线| 一区二区av在线| 亚洲一区二区三区中文字幕| 香蕉久久夜色精品国产| 久久精品国产亚洲a| 亚洲人成网站在线播| 在线综合亚洲| 欧美伊人精品成人久久综合97 | 欧美日韩成人一区二区| 国产精品xxxxx| 国产亚洲欧美另类一区二区三区| 在线不卡亚洲| 99精品久久| 欧美一区国产一区| 亚洲精品一区二区三区福利| 国产精品99久久久久久有的能看| 午夜在线视频一区二区区别| 久久综合九色99| 欧美三级不卡| 国产在线成人| 亚洲精品一区二区三区樱花| 亚洲综合99| 亚洲精品四区| 亚洲欧美精品在线观看| 老牛国产精品一区的观看方式| 欧美日韩精品欧美日韩精品| 国产伦精品一区二区三区视频孕妇| 亚洲大胆女人| 亚洲欧美不卡| 亚洲精品综合精品自拍| 欧美怡红院视频| 欧美精品网站| 国产亚洲一级高清| 亚洲精品专区| 亚洲成在人线av| 亚洲一区二区三区视频| 久久一区二区三区国产精品| 国产精品国产三级国产aⅴ浪潮| 黄色欧美日韩| 亚洲天堂av图片| 亚洲欧洲另类| 久久久久久免费| 国产精品高清网站| 亚洲国产日韩欧美在线动漫| 午夜精品久久| 亚洲私拍自拍| 欧美91大片| 国产一区二区0| 中文精品99久久国产香蕉| 亚洲人在线视频| 久久久久久一区二区| 国产精品爱久久久久久久| 亚洲国内精品| 亚洲黄色免费网站| 久久精品人人做人人爽| 国产精品久久久久久久久婷婷 | 亚洲一区二区精品视频| 日韩午夜视频在线观看| 久久人人97超碰精品888| 国产精品自拍小视频| 一本色道久久综合狠狠躁篇怎么玩| 亚洲国产精品嫩草影院| 久久国产精品一区二区三区| 欧美丝袜一区二区三区| 亚洲精品1区| 亚洲欧洲视频在线| 久久婷婷激情| 国外成人免费视频| 欧美一区2区三区4区公司二百| 亚洲欧美日韩精品一区二区| 欧美日韩一区二区视频在线| 亚洲人成毛片在线播放| 亚洲人成7777| 美国十次成人| 永久久久久久| 亚洲国产精品福利| 蜜臀久久99精品久久久久久9 | 亚洲福利国产| 亚洲国产精品va| 噜噜噜躁狠狠躁狠狠精品视频| 国产一区二区三区高清在线观看| 亚洲欧美国产精品桃花| 亚洲免费在线电影| 国产精品日日摸夜夜摸av| 亚洲夜间福利| 欧美一区二区三区四区夜夜大片| 国产精品免费一区豆花| 亚洲专区一区| 午夜亚洲福利在线老司机| 国产精品一区二区三区四区| 亚洲一区免费视频| 欧美在线啊v| 国产字幕视频一区二区| 久久精品国产精品 | 欧美在线影院| 久久色在线播放| 在线观看一区二区视频| 亚洲欧洲在线看| 欧美精品性视频| 一区二区免费看| 香蕉久久夜色精品国产使用方法| 国产精品美女999| 欧美一区二区三区视频免费播放| 久久噜噜噜精品国产亚洲综合| 一区在线视频| 亚洲精品日韩一| 欧美日韩精品高清| 亚洲综合色激情五月| 久久久久久一区二区| 亚洲国产成人久久综合一区| 99精品国产在热久久婷婷| 国产精品扒开腿做爽爽爽软件| 亚洲伊人观看| 久久一二三国产| 亚洲精品一区二区三区四区高清| 亚洲欧美日产图| 黄色另类av| 亚洲深夜影院| 国产伦精品一区二区三区高清版 | 亚洲一级在线观看| 久久精品观看| 亚洲国产清纯| 亚洲欧美日韩一区在线| 国产综合色在线| 99国产精品99久久久久久粉嫩| 欧美少妇一区二区| 欧美呦呦网站| 欧美日本一区二区三区| 亚洲欧美视频一区二区三区| 嫩草成人www欧美| 一本色道久久综合亚洲精品按摩 | 午夜精品久久久久久久99樱桃 | 国内外成人免费激情在线视频网站| 91久久夜色精品国产网站| 欧美午夜a级限制福利片| 午夜精品剧场| 欧美精品成人一区二区在线观看| 亚洲一区国产视频| 免费在线看一区| 亚洲一区二区三区在线| 免费在线观看成人av| 亚洲一区二区三区三| 久久久久国产一区二区三区四区| 亚洲日本无吗高清不卡| 欧美一区二区三区男人的天堂| 在线看片成人| 欧美怡红院视频| 亚洲免费av网站| 久久久一二三| 亚洲小说春色综合另类电影| 欧美成人午夜影院| 亚洲自拍三区| 欧美日韩精品一区| 亚洲高清激情| 国产农村妇女毛片精品久久莱园子| 亚洲精品一区二区三| 国产日韩在线看片| 亚洲影院色在线观看免费| 亚洲国产精品久久久久婷婷884| 亚洲淫性视频| 91久久精品日日躁夜夜躁国产| 久久久99免费视频| 亚洲视频久久| 欧美日韩一区二区在线观看视频 | 99精品福利视频|