首頁 資料庫 mysql教程 SQL語句效率問題的幾點總結

SQL語句效率問題的幾點總結

Dec 20, 2016 pm 01:44 PM
sql

1. SQL最佳化的原則是:

  將一次操作需要讀取的BLOCK數減到最低,即在最短的時間達到最大的資料吞吐量。
  調整不良SQL通常可以從以下幾點切入:   
  檢查不良的SQL,考慮其寫法是否還有可最佳化內容   
  檢查子查詢   使用   
  考慮資料庫的最佳化器

2. 避免出現SELECT   *   FROM   table     語句,且要明確找出的欄位。     

    
3. 在一個SQL語句中,如果一個where條件過濾的資料庫記錄越多,

    定位越準確,則該where條件越應前移。   

    
4. 查詢時盡可能使用索引覆蓋。即對SELECT的欄位建立複合索引,

    這樣查詢時只進行索引掃描,不讀取資料區塊。

5. 判斷有無符合條件的記錄時建議不要用SELECT   COUNT   (*)和select   top   1   語句。   

    
6. 使用內層限定原則,在拼字SQL語句時,將查詢條件分解、分類,

    並盡量在SQL語句的最裡層進行限定,以減少資料的處理量。   

    
7. 應絕對避免在order   by子句中使用表達式。   
    
8. 若需要從關聯表讀數據,因此關聯的表一般不要超過7個。   
    
9. 小心使用   IN   與   OR,且需要注意In集合中的資料量。建議集合中的資料不超過200個。   
    
10.    以      來代替,且>以>=代替,    
11. 查詢時盡量減少多餘資料的讀取包括多餘的列與多餘的行。
    
12. 複合索引要注意,例如在建立複合索引時列的順序是F1,F2,F3,

     則在where或order   by子句中這些字段出現的順序順序與索引一致,

    且必須包含第  一列。只能是F1或F1,F2或F1,F2,F3。否則不會用到該索引。 

13. 多表關聯查詢時,寫法必須遵循以下原則,這樣做有利於建立索引,提高查詢效率。

     格式如下

     select   sum(table1.je)   from   table1       

     table3     table3   where   (table1的等值條件(=))   and   (table1的非等值條件) 

table1的關聯條件)   and (table2的等值條件)   and   (table2的非等值條件)    

     and (table3與table2的相關條件)   and   (table3的等值條件關聯條件。   

     注意:關於多表查詢時from     後表的出現順序對效率的影響仍有待研究。   

    
14. 子查詢問題。對於能用連接方式或視圖方式實現的功能,不要用子查詢。

     例如:select   name    from   customer   where  

     customer_ money>1000)。

     應使用下列語句取代:select   name   from   customer  

    inner   join     where   order.money>100。   

    

15. 在WHERE   子句中,避免對列的四則運算,

     特別是where   條件的左邊,嚴禁使用運算與函數對列進行處理。

     例如有些地方   substring   可用like取代。   
    
16. 如果在語句中有not   in(in)操作,

     應考慮使用not   exists(exists)來重寫,最好的方法是使用外部連接。
      
17. 對一個業務流程的處理,應該使事物的開始與結束之間的時間間隔越短越好,

     原則上做到,資料庫寫入作業在後面完成,避免交叉。

18. 小心不要對過多的列使用列函數和order   by,group   by等,並謹慎使用disti軟體開發t。   
    
19. 使用union   all   取代   union,且資料庫執行union操作,

        

     當已知的業務邏輯決定query   A和query   B不會重複記錄時,


     應以union   all取代效率。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Hibernate 框架中 HQL 和 SQL 的差異是什麼? Hibernate 框架中 HQL 和 SQL 的差異是什麼? Apr 17, 2024 pm 02:57 PM

HQL和SQL在Hibernate框架中進行比較:HQL(1.物件導向語法,2.資料庫無關的查詢,3.類型安全),而SQL直接操作資料庫(1.與資料庫無關的標準,2.可執行複雜查詢和資料操作)。

Oracle SQL中除法運算的用法 Oracle SQL中除法運算的用法 Mar 10, 2024 pm 03:06 PM

《OracleSQL中除法運算的用法》在OracleSQL中,除法運算是常見的數學運算之一。在資料查詢和處理過程中,除法運算可以幫助我們計算欄位之間的比例或得出特定數值的邏輯關係。本文將介紹OracleSQL中除法運算的用法,並提供具體的程式碼範例。一、OracleSQL中除法運算的兩種方式在OracleSQL中,除法運算可以用兩種不同的方式來進行

Oracle與DB2的SQL語法比較與區別 Oracle與DB2的SQL語法比較與區別 Mar 11, 2024 pm 12:09 PM

Oracle和DB2是兩個常用的關聯式資料庫管理系統,它們都有自己獨特的SQL語法和特性。本文將針對Oracle和DB2的SQL語法進行比較與區別,並提供具體的程式碼範例。資料庫連接在Oracle中,使用以下語句連接資料庫:CONNECTusername/password@database而在DB2中,連接資料庫的語句如下:CONNECTTOdataba

詳解MyBatis動態SQL標籤中的Set標籤功能 詳解MyBatis動態SQL標籤中的Set標籤功能 Feb 26, 2024 pm 07:48 PM

MyBatis動態SQL標籤解讀:Set標籤用法詳解MyBatis是一個優秀的持久層框架,它提供了豐富的動態SQL標籤,可以靈活地建構資料庫操作語句。其中,Set標籤是用來產生UPDATE語句中SET子句的標籤,在更新作業中非常常用。本文將詳細解讀MyBatis中Set標籤的用法,以及透過具體的程式碼範例來示範其功能。什麼是Set標籤Set標籤用於MyBati

SQL中的identity屬性是什麼意思? SQL中的identity屬性是什麼意思? Feb 19, 2024 am 11:24 AM

SQL中的Identity是什麼,需要具體程式碼範例在SQL中,Identity是一種用於產生自增數字的特殊資料類型,它常用於唯一識別表中的每一行資料。 Identity欄位通常與主鍵列搭配使用,可確保每筆記錄都有獨一無二的識別碼。本文將詳細介紹Identity的使用方式以及一些實際的程式碼範例。 Identity的基本使用方式在建立表格時,可以使用Identit

Springboot+Mybatis-plus不使用SQL語句進行多表新增怎麼實現 Springboot+Mybatis-plus不使用SQL語句進行多表新增怎麼實現 Jun 02, 2023 am 11:07 AM

在Springboot+Mybatis-plus不使用SQL語句進行多表添加操作我所遇到的問題準備工作在測試環境下模擬思維分解一下:創建出一個帶有參數的BrandDTO對像模擬對後台傳遞參數我所遇到的問題我們都知道,在我們使用Mybatis-plus中進行多表操作是極其困難的,如果你不使用Mybatis-plus-join這一類的工具,你只能去配置對應的Mapper.xml文件,配置又臭又長的ResultMap,然後再寫對應的sql語句,這種方法雖然看上去很麻煩,但具有很高的靈活性,可以讓我們

SQL出現5120錯誤怎麼解決 SQL出現5120錯誤怎麼解決 Mar 06, 2024 pm 04:33 PM

解決方法:1、檢查登入使用者是否具有足夠的權限來存取或操作該資料庫,確保該使用者俱有正確的權限;2、檢查SQL Server服務的帳戶是否具有存取指定檔案或資料夾的權限,確保該帳戶具有足夠的權限來讀取和寫入該文件或資料夾;3、檢查指定的資料庫文件是否已被其他進程打開或鎖定,嘗試關閉或釋放該文件,並重新運行查詢;4、嘗試以管理員身份運行Management Studio等等。

如何使用SQL語句在MySQL中進行資料聚合和統計? 如何使用SQL語句在MySQL中進行資料聚合和統計? Dec 17, 2023 am 08:41 AM

如何使用SQL語句在MySQL中進行資料聚合和統計?在進行資料分析和統計時,資料聚合和統計是非常重要的步驟。 MySQL作為一個功能強大的關聯式資料庫管理系統,提供了豐富的聚合和統計函數,可以很方便地進行資料聚合和統計操作。本文將介紹使用SQL語句在MySQL中進行資料聚合和統計的方法,並提供具體的程式碼範例。一、使用COUNT函數進行計數COUNT函數是最常用

See all articles