成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何編寫更好的SQL查詢語句

數據庫
反向模型中隱含的事實是,建立查詢時基于集合和程序的方法之間存在著不同。由于 SQL 是基于集合的,所以這種方法比起程序方法更加有效,這也解釋了為什么在某些情況下,SQL 可以比代碼工作地更快。

[[202756]]

基于集合和程序的方法進行查詢

反向模型中隱含的事實是,建立查詢時基于集合和程序的方法之間存在著不同。

  • 查詢的程序方法是一種非常類似于編程的方法:你告訴系統需要做些什么以及如何做。例如上一篇文章中的示例,通過執行一個函數然后調用另一個函數來查詢數據庫,或者使用包含循環、條件和用戶定義函數(UDF)的邏輯方式來獲得最終查詢結果。你會發現通過這種方式,一直在請求一層一層中數據的子集。這種方法也經常被稱為逐步或逐行查詢。
  • 另一種是基于集合的方法,只需指定需要執行的操作。使用這種方法要做的事情就是,指定你想通過查詢獲得的結果的條件和要求。在檢索數據過程中,你不需要關注實現查詢的內部機制:數據庫引擎會決定最佳的執行查詢的算法和邏輯。

由于 SQL 是基于集合的,所以這種方法比起程序方法更加有效,這也解釋了為什么在某些情況下,SQL 可以比代碼工作地更快。

基于集合的查詢方法也是數據挖掘分析行業要求你必須掌握的技能!因為你需要熟練的在這兩種方法之間進行切換。如果你發現自己的查詢中存在程序查詢,則應該考慮是否需要重寫這部分。

從查詢到執行計劃

反向模式不是靜止不變的。在你成為 SQL 開發者的過程中,避免查詢反向模型和重寫查詢可能會是一個很艱難的任務。所以時常需要使用工具以一種更加結構化的方法來優化你的查詢。

對性能的思考不僅需要更結構化的方法,還需要更深入的方法。

然而,這種結構化和深入的方法主要是基于查詢計劃的。查詢計劃首先被解析為“解析樹”并且準確定義了每個操作使用什么算法以及如何協調操作過程。

查詢優化

在優化查詢時,很可能需要手動檢查優化器生成的計劃。在這種情況下,將需要通過查看查詢計劃來再次分析你的查詢。

要掌握這樣的查詢計劃,你需要使用一些數據庫管理系統提供給你的工具。你可以使用以下的一些工具:

  • 一些軟件包功能工具可以生成查詢計劃的圖形表示。
  • 其它工具能夠為你提供查詢計劃的文本描述。

請注意,如果你正在使用 PostgreSQL,則可以區分不同的 EXPLAIN,你只需獲取描述,說明 planner 如何在不運行計劃的情況下執行查詢。同時 EXPLAIN ANALYZE 會執行查詢,并返回給你一個評估查詢計劃與實際查詢計劃的分析報告。一般來說,實際執行計劃會切實的執行這個計劃,而評估執行計劃可以在不執行查詢的情況下,解決這個問題。在邏輯上,實際執行計劃更為有用,因為它包含了執行查詢時,實際發生的其它細節和統計信息。

接下來你將了解 XPLAIN 和 ANALYZE 的更多信息,以及如何使用這兩個命令來進一步了解你的查詢計劃和查詢性能。要做到這一點,你需要開始使用兩個表: one_million 和 half_million 來做一些示例。

你可以借助 EXPLAIN 來檢索 one_million 表的當前信息:確保已將其放在運行查詢的首要位置,在運行完成之后,會返回到查詢計劃中:

  1. EXPLAIN 
  2. SELECT * 
  3. FROM one_million; 
  4. QUERY PLAN 
  5. _________________________________________________ 
  6. Seq Scan on one_million 
  7. (cost=0.00..18584.82 rows=1025082 width=36) 
  8. (1 row)  

在以上示例中,我們看到查詢的 Cost 是0.00..18584.82 ,行數是1025082,列寬是36。

同時,也可以借助 ANALYZE 來更新統計信息 。

  1. ANALYZE one_million; 
  2. EXPLAIN 
  3. SELECT * 
  4. FROM one_million; 
  5. QUERY PLAN 
  6. _________________________________________________ 
  7. Seq Scan on one_million 
  8. (cost=0.00..18334.00 rows=1000000 width=37) 
  9. (1 row)  

除了 EXPLAIN 和 ANALYZE,你也可以借助 EXPLAIN ANALYZE 來檢索實際執行時間:

  1. EXPLAIN ANALYZE 
  2. SELECT * 
  3. FROM one_million; 
  4. QUERY PLAN 
  5. ___________________________________________________ 
  6. Seq Scan on one_million 
  7. (cost=0.00..18334.00 rows=1000000 width=37) 
  8. (actual time=0.015..1207.019 rows=1000000 loops=1) 
  9. Total runtime: 2320.146 ms 
  10. (2 rows) 

使用 EXPLAIN ANALYZE 的缺點就是需要實際執行查詢,這點值得注意!

到目前為止,我們看到的所有算法是順序掃描或全表掃描:這是一種在數據庫上進行掃描的方法,掃描的表的每一行都是以順序(串行)的順序進行讀取,每一列都會檢查是否符合條件。在性能方面,順序掃描不是最佳的執行計劃,因為需要掃描整個表。但是如果使用慢磁盤,順序讀取也會很快。

還有一些其它算法的示例:

  1. EXPLAIN ANALYZE 
  2. SELECT * 
  3. FROM one_million JOIN half_million 
  4. ON (one_million.counter=half_million.counter); 
  5. QUERY PLAN 
  6. _____________________________________________________________ 
  7. Hash Join (cost=15417.00..68831.00 rows=500000 width=42) 
  8. (actual time=1241.471..5912.553 rows=500000 loops=1) 
  9. Hash Cond: (one_million.counter = half_million.counter) 
  10.     -> Seq Scan on one_million 
  11.     (cost=0.00..18334.00 rows=1000000 width=37) 
  12.     (actual time=0.007..1254.027 rows=1000000 loops=1) 
  13.     -> Hash (cost=7213.00..7213.00 rows=500000 width=5) 
  14.     (actual time=1241.251..1241.251 rows=500000 loops=1) 
  15.     Buckets: 4096 Batches: 16 Memory Usage: 770kB 
  16.     -> Seq Scan on half_million 
  17.     (cost=0.00..7213.00 rows=500000 width=5) 
  18. (actual time=0.008..601.128 rows=500000 loops=1) 
  19. Total runtime: 6468.337 ms  

我們可以看到查詢優化器選擇了 Hash Join。請記住這個操作,因為我們需要使用這個來評估查詢的時間復雜度。我們注意到了上面示例中沒有 half_million.counter 索引,我們可以在下面示例中添加索引 :

  1. CREATE INDEX ON half_million(counter); 
  2. EXPLAIN ANALYZE 
  3. SELECT * 
  4. FROM one_million JOIN half_million 
  5. ON (one_million.counter=half_million.counter); 
  6. QUERY PLAN 
  7. ______________________________________________________________ 
  8. Merge Join (cost=4.12..37650.65 rows=500000 width=42) 
  9. (actual time=0.033..3272.940 rows=500000 loops=1) 
  10. Merge Cond: (one_million.counter = half_million.counter) 
  11.     -> Index Scan using one_million_counter_idx on one_million 
  12.     (cost=0.00..32129.34 rows=1000000 width=37) 
  13.     (actual time=0.011..694.466 rows=500001 loops=1) 
  14.     -> Index Scan using half_million_counter_idx on half_million 
  15.     (cost=0.00..14120.29 rows=500000 width=5) 
  16. (actual time=0.010..683.674 rows=500000 loops=1) 
  17. Total runtime: 3833.310 ms 
  18. (5 rows 

通過創建索引,查詢優化器已經決定了索引掃描時,如何查找 Merge join。

請注意,索引掃描和全表掃描(順序掃描)之間的區別:后者(也稱為“表掃描”)是通過掃描所有數據或索引所有頁面來查找到適合的結果,而前者只掃描表中的每一行。 

責任編輯:龐桂玉 來源: 葡萄城控件技術團隊的博客
相關推薦

2021-06-09 10:45:12

JavaScript開發 編程

2021-03-17 08:00:59

JS語言Javascript

2010-02-02 13:59:11

Python編寫

2023-10-10 08:00:00

2010-02-03 09:27:21

編寫Python程序

2022-07-28 09:13:30

MySQL數據庫

2010-10-21 12:16:11

SQL Server查

2010-09-26 15:23:24

SQL語句

2016-12-15 09:58:26

優化SQL高性能

2017-07-12 13:04:23

數據庫SQL查詢執行計劃

2009-04-28 09:38:53

SQL優化物理查詢

2022-02-11 14:43:53

SQL語句C/S架構

2014-04-21 10:14:52

PromisesJavaScript

2010-09-28 14:33:13

SQL語句

2019-11-06 09:30:35

SQL查詢語句數據庫

2010-09-07 10:35:38

SQL語句

2010-09-28 11:28:40

SQL字段屬性

2010-09-24 19:23:51

SQL查詢時間段

2010-09-26 17:09:05

SQL語句

2010-10-21 10:28:13

SQL Server查
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久综合一区 | 色偷偷人人澡人人爽人人模 | 伊人免费观看视频 | 精品1区2区 | 国产一区| 成人视屏在线观看 | 大陆一级毛片免费视频观看 | 午夜精品久久久久久久久久久久久 | 亚洲成人一区二区在线 | 国产丝袜一区二区三区免费视频 | 欧美激情在线观看一区二区三区 | 九九亚洲 | 欧美色欧美亚洲另类七区 | 久久国产一区二区 | 亚洲人成在线播放 | 成人av一区二区三区 | 日韩国产一区二区三区 | 韩日视频在线观看 | 国产精品欧美一区二区 | 欧美在线视频一区二区 | 国产a爽一区二区久久久 | 日韩免费一区二区 | 中文字幕一区二区三区四区五区 | 日韩视频中文字幕 | 日韩欧美在线一区二区 | 亚洲精品乱码 | 中文字幕1区2区3区 亚洲国产成人精品女人久久久 | 亚洲性爰| 狠狠操狠狠操 | 日韩中文字幕免费在线 | 四虎影院在线免费观看 | 欧美精品欧美精品系列 | 毛片一区二区三区 | 日韩中文字幕一区二区 | 黄色在线免费网站 | 九九导航| 欧美精品一二三区 | 国产黄色一级片 | 国产在线aa| 日本三级日产三级国产三级 | 国产96在线 |