亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > 文庫 > 正文

如何編寫更好的SQL查詢終極攻略-第一部分

2024-09-07 22:13:01
字體:
來源:轉載
供稿:網友
  結構化查詢語言(SQL)是數據挖掘分析行業不可或缺的一項技能,總的來說,學習這個技能是比較容易的。對于SQL來說,編寫查詢語句只是第一步,確保查詢語句高效并且適合于你的數據庫操作工作,才是最重要的。這個教程將會提供給你一些步驟,來評估你的查詢語句。

  為什么要學SQL?
  尋找數據挖掘分析行業的工作,SQL是最需要的技能之一,不論是申請數據分析工作、數據引擎工作、數據挖掘分析或者其它工作。在O'Reilly發布的《2016數據科學從業者薪酬報告》中,有70%的受訪者證實了這一點,表示他們需要在專業環境中使用SQL。此外,本次調查中,SQL遠勝于R(57%)和Python(54%)等編程語言。所以在數據挖掘分析領域,SQL是必備技能。
 
  我們分析一下SQL從1970s早期開發出,到現在還經久不衰的原因:
 
  一、公司基本都將數據存儲在關系數據庫管理系統(RDBMS)或關系數據流管理系統(RDSMS)中,所以需要使用SQL來實現訪問。SQL是通用的數據語言,可以使用SQL和幾乎其它任何數據庫進行交互,甚至可以在本地建立自己的數據庫!
 
  二、只有少量的SQL實現沒有遵循標準,在供應商之間不兼容。因此,了解SQL標準是在數據挖掘分析行業立足的必要要求。
 
  三、最重要的是SQL也被更新的技術所接受,例如Hive或者Spark SQL。Hive是一個用于查詢和管理大型數據集的類似于SQL的查詢語言界面;Spark SQL可用于執行SQL查詢。
 
  為了提高SQL查詢的性能,首先需要知道,運行查詢時,內部會發生什么。
 
  以下時查詢執行的過程:
 
  首先,將查詢解析成“解析樹”; 分析查詢是否滿足語法和語義要求。解析器將會創建一個輸入查詢的內部表示,然后將此輸出傳遞給重寫引擎。
  然后,優化器的任務是為給定的查詢,尋找最佳執行或查詢計劃。執行計劃準確地定義了每個操作所使用的算法,以及如何協調操作的執行。
  最后,為了找到最佳的執行計劃,優化器會列舉所有可能的執行計劃,并確定每個計劃的質量或成本,以便獲取有關當前數據庫狀態的信息,最后選擇最佳的執行計劃。由于查詢優化器可能不完善,因此數據庫用戶和管理員有時需要手動檢查并調整優化器生成的計劃,以便獲得更好的性能。
  現在你已經清楚了什么才是好的執行計劃。
 
  正如前面了解到的,計劃的成本質量起著重要的作用。更具體地說,評估計劃所需的磁盤I / O數量,計劃的CPU花銷以及數據庫客戶端的整體響應時間和總執行時間等因素至關重要。這就是時間復雜性的概念。后面還將繼續了解。
 
  接下來,執行所選擇的查詢計劃,由系統的執行引擎進行評估,并返回查詢結果。
 
  編寫SQL查詢
  需要進一步說明的是,垃圾回收原則(GIGO)原本就是表達在查詢處理和執行之中:制定查詢的人,同時也決定著SQL查詢的性能。
 
  這意味著在編寫查詢,有些事情可以同步去做。就像文章開始時介紹的,編寫查詢需要遵循兩個標準:首先,編寫的查詢需要滿足一定的標準,其次還應該應對查詢中可以出現的性能問題。
 
  總的來說,有四個分句和關鍵字,方便新手考慮性能問題:
 
  WHERE 分句
  INNER JOIN 和 LEFT JOIN 關鍵字
  HAVING 分句
  雖然這種做法簡單而天真,但對于一個初學者來說,這些方法卻是一個很好的指引。這些地方也是你剛開始編寫時,容易發生錯誤的地方,這些錯誤也很難發現。
 
  同時,要想提升性能,使其變得有意義,就不能脫離上下文:在考慮SQL性能時,不能武斷的認為上面的分句和關鍵字不好。使用WHERE 或 HAVING的分句也可能是很好的查詢語句。
 
  通過下面的章節來來進一步了解編寫查詢時反向模型和代替方法,并將這些提示和技巧作為指導。如何重寫查詢和是否需要重寫查詢取決于數據量,以及數據庫和執行查詢所需的次數等。這完全取決于你的查詢目標,事先掌握一些有關數據的知識是非常重要的!
 
  1. 僅檢索你需要的數據
  在編寫SQL查詢時,并不是數據越多越好。因此在使用SELECT 語句、DISTINCT分句和LIKE操作符時,需要謹慎。
 
  SELECT聲明
 
  在編寫完查詢語句之后,首先需要做的事情就是檢查select語句是否簡潔。你的目標應該是刪除不必要的select列。以便只取到符合你查詢目的的數據。
 
  如果還有相關使用exists的子查詢,那么就應該在select語句中使用常量,而不是選擇實際列的值。當檢查實體時,這是特別方便的。
 
  請記住,相關子查詢是使用外部查詢中的值的子查詢,并且在這種情況下,NULL是可以作為“常量”的,這點確實令人困惑!
 
  2. 縮小查詢結果
  如果無法避免使用 SELECT語句時,可以考慮通過其它方式縮小查詢結果。例如,使用LIMIT 分句和數據類型轉換的方法。
 
  TOP,LIMIT和ROWNUM分句
 
  可以在查詢中添加LIMIT或TOP分句,來設置查詢結果的最大行數。下面是一個示例:
 
  SELECT TOP 3 *FROM Drivers;
  請注意,你可以進一步指定PERCENT。
 
  例如,如果你想更改查詢的第一行  SELECT TOP 50 PERCENT *。
 
  SELECT driverslicensenr, nameFROM Drivers
  LIMIT 2;
  此外,你還可以添加ROWNUM 分句,相應于在查詢中使用的LIMIT:
 
  SELECT *FROM DriversWHERE driverslicensenr = 123456 AND ROWNUM <= 3;
  數據類型轉換
  應該使用最小的數據類型,因為小的數據類型更加有效。
 
  當查詢中需要進行數據類型轉化,會增加執行時間,所以盡可能的避免數據類型轉換的發生;
 
  如果不能避免的話,需要謹慎的定義數據類型的轉換。
 
  本文是本系列教程的第一篇,后續還有更多《如何編寫更好的SQL查詢》的文章分享給大家,敬請期待。

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品91一区| 69av视频在线播放| 国产91在线播放精品91| 91精品中国老女人| 日本一区二区三区四区视频| 视频一区视频二区国产精品| 中文字幕亚洲一区二区三区| 欧美理论电影在线观看| 韩国19禁主播vip福利视频| 亚洲一区二区免费| 综合久久五月天| 中文字幕日韩av| 亚洲最大福利视频网站| 国产视频丨精品|在线观看| 日韩欧美国产高清91| 欧美黄色成人网| 国产a∨精品一区二区三区不卡| 91视频8mav| 亚洲 日韩 国产第一| 日韩精品免费一线在线观看| 日韩欧美在线中文字幕| 欧美壮男野外gaytube| 久久亚洲成人精品| 亚洲成人黄色在线| 久久久久久久久国产| 国产欧美在线播放| 午夜精品www| 国产成人激情小视频| 欧美老女人bb| 国产精品av电影| 亚洲人在线视频| 性亚洲最疯狂xxxx高清| 亚洲欧美国产一区二区三区| 精品一区精品二区| 欧美丰满少妇xxxx| 欧美精品午夜视频| 午夜精品久久久久久久99黑人| 国模精品视频一区二区三区| 中文字幕亚洲无线码在线一区| 欧美最近摘花xxxx摘花| 日本一区二区在线播放| 亚洲精品www久久久久久广东| 97色在线视频观看| 日韩免费看的电影电视剧大全| 欧美成人四级hd版| 97涩涩爰在线观看亚洲| 亚洲一区精品电影| 亚洲国产另类久久精品| 最近日韩中文字幕中文| 国产精品69精品一区二区三区| 亚洲最大激情中文字幕| 国产精品久久久久7777婷婷| 久久亚洲综合国产精品99麻豆精品福利| 国产精品视频久久久久| 欧美亚洲成人精品| 日韩国产在线播放| 久久躁日日躁aaaaxxxx| 欧美日韩中文字幕在线视频| 日韩大片免费观看视频播放| 久久97久久97精品免视看| 亚洲变态欧美另类捆绑| 亚洲国产精品免费| 欧美成人合集magnet| 成人乱人伦精品视频在线观看| 亚洲国产成人av在线| 国产一区二区三区在线视频| 欧美综合在线第二页| 国模精品视频一区二区| 国产成人精品一区二区三区| 欧美日韩激情视频8区| 亚洲v日韩v综合v精品v| 国产精品观看在线亚洲人成网| 91中文精品字幕在线视频| 成人免费网视频| 亚洲欧美在线免费观看| 国产精品99导航| 国产精品免费在线免费| 日韩免费观看高清| 91精品国产免费久久久久久| 久久免费少妇高潮久久精品99| 久热精品在线视频| 午夜精品久久久久久99热| 久久久久久久久爱| 亚洲wwwav| 欧美激情视频在线观看| 91精品国产高清久久久久久91| 亚洲欧美中文日韩在线| 欧美精品videossex性护士| 久久精品国产欧美亚洲人人爽| 亚洲精品福利视频| 清纯唯美亚洲综合| 亚洲欧美另类人妖| 欧美一级淫片播放口| 成人a视频在线观看| 亚洲天堂男人天堂| 国产精品pans私拍| 日韩中文字幕在线视频| 中文字幕欧美精品日韩中文字幕| 亚洲丝袜av一区| 久久免费视频这里只有精品| 激情懂色av一区av二区av| 久久久视频精品| 亚洲天堂久久av| 欧美日韩在线视频一区| 欧美福利小视频| 在线观看国产欧美| 欧美性猛交xxxx乱大交3| 日韩免费在线视频| 国产精品麻豆va在线播放| 成人黄色大片在线免费观看| 久久国产精品99国产精| 97在线视频免费| 91产国在线观看动作片喷水| 最近中文字幕mv在线一区二区三区四区| 亚洲美女又黄又爽在线观看| 国产精品高潮粉嫩av| 欧美激情中文字幕乱码免费| 欧美日韩亚洲视频| 久久综合88中文色鬼| 成人免费网视频| 日韩成人高清在线| 啊v视频在线一区二区三区| 国产在线a不卡| 中文字幕亚洲欧美在线| 精品久久久久国产| 欧美电影在线观看| 国自在线精品视频| 国产丝袜视频一区| 国内伊人久久久久久网站视频| 日韩av在线直播| 国产精品视频久久久| 伊人av综合网| 国产精品白嫩初高中害羞小美女| 国产精品久久久久久久久久| 高清视频欧美一级| 精品亚洲永久免费精品| 亚洲a成v人在线观看| 欧美亚洲视频一区二区| 亚洲国产欧美在线成人app| 精品视频久久久久久久| 中日韩美女免费视频网址在线观看| 国产精品99蜜臀久久不卡二区| 久久久久国产一区二区三区| 国产精品视频大全| 国产精品免费视频久久久| 亚洲免费视频一区二区| 中文字幕欧美国内| 在线成人激情黄色| 久久久久久久久久婷婷| 97精品视频在线观看| 日韩中文字幕视频在线观看| 日韩经典中文字幕在线观看| 都市激情亚洲色图| 国产经典一区二区| 97在线精品国自产拍中文| 国产激情999| 国产欧美日韩精品丝袜高跟鞋| 91国内精品久久| 亚洲乱码一区av黑人高潮| 亚洲视频电影图片偷拍一区| 久久最新资源网| 亚洲免费高清视频| 日韩av免费看网站| 国产偷国产偷亚洲清高网站|