6 個SQL查詢性能優化方法,讓你查詢效率提高80%!
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
SQL 查詢性能的優化,是面試中的高頻知識點,也是必知必會的技能。 SQL 查詢性能的好壞,直接影響程序性能和用戶體驗。特別是一些數據量大、復雜多樣的應用場景中,對 SQL 查詢性能優化就更加剛需。 本文主要介紹六個常用的 SQL 查詢性能優化方法。 《阿里巴巴開發手冊》中指出: 【強制】在表查詢中,一律不要使用 * 作為查詢的字段列表,需要哪些字段必須明確寫明說明。 select * 的問題及影響 在 SQL 語句中,select * 是最常見的寫法之一,表示返回所有的字段。 當查詢的表中包含大量字段的時候,這種寫法既浪費帶寬和 I/O 資源,還會造成緩存和 CPU 的過度使用,嚴重影響 SQL 的查詢性能。 如何正確使用 select 語句 正確使用 select 語句的方法是僅選擇需要的字段,既能提升查詢效率,還能讓結果集更易于理解和處理。 例如:對于一張包含 100 個字段的表,如果只需要其中的 10 個字段,那么就應該這樣寫: select field1, field2, field3, field4, field5, field6, field7, field8, field9, field10 from table_name; 只返回需要的 10 個字段,極大地減少查詢的時間和資源消耗。 在 SQL 查詢中,一個表可能與其他多個表進行關聯,關聯的表之間可能存在大小的差異。 在關聯時,讓小表驅動大表就能提高查詢性能。這是因為小表的數據量較小,更容易被緩存,而大表的數據量很大,會占用大量的 I/O 資源,導致查詢變慢。 小表驅動大表的示例 具體來說,就是我們可以通過將大表作為外部表(right join/left join),從而實現小表驅動大表。這樣在查詢時就可以優先使用小表的緩存,減少 I/O 開銷。 例如:
下面是一個使用小表驅動大表的示例: select * from small_tableLEFT JOIN big_tableON small_table.id = big_table.id; 這個查詢語句中,small_table 是小表,big_table 是大表,通過 left join 關鍵字,我們讓 small_table 作為驅動表。 這樣,在查詢時,系統會優先使用 small_table 的緩存,減少 I/O 開銷,提高查詢效率。 在 SQL 查詢中,join 語句是常用的語句之一,但過多的 join 關聯表會極大地影響 SQL 查詢的性能。 這是因為:每個 join 語句都需要執行一次關聯操作,從而導致了 SQL 查詢的復雜度成倍增加,同時也降低了數據庫的響應速度。 如何減少 join 的使用呢
join 關聯表過多的解決方法 舉個例子:
這種情況下,我們就可以考慮使用其他方式來減少關聯表的數量。譬如,先將 B 表中的數據按照某種條件進行篩選,再將其與 A 表進行關聯。這樣就能將關聯的數據量減少到一個可控范圍內,提高了 SQL 查詢的性能。 在 SQL 查詢中,左模糊和全模糊查詢都是非常耗費資源的查詢方式,會造成嚴重的性能問題。 這是因為:在查詢過程中,需要對每一條數據進行全文搜索,這樣就會導致查詢速度非常慢,甚至導致數據庫的性能嚴重下降。 正確使用模糊查詢,才能提高查詢性能,減少查詢開銷。 使用模糊查詢時,需要注意以下幾點:
示例: 假設我們要查詢某個表中以 “abc” 開頭的用戶名: select * from user where name LIKE '%abc'; 使用上面的語句,即便表中只有少量以 “abc” 開頭的用戶名,這樣的查詢也會導致全表掃描,造成不必要的開銷,極大地影響查詢性能。 我們可以使用下面這個語句: select * from user where name LIKE 'abc%'; 利用前綴索引來加速查詢,避免了全表掃描,極大提高了查詢性能。 索引訪問類型是指 MySQL 在查詢數據時使用的索引方式,通常分為全值匹配、范圍查詢、索引掃描和全表掃描等多種方式。 其中,索引訪問類型不到 range 級別的查詢方式,就會對查詢性能造成較大的影響。 索引訪問類型的問題及影響 當索引訪問類型不到 range 級別時,MySQL 在查詢數據時需要對索引進行全表掃描或索引掃描,導致查詢效率低下,查詢速度變慢,嚴重影響系統的性能。 如何正確使用索引 以下是一些使用索引的建議:
索引訪問類型不到 range 級別的解決方法 如下,索引訪問類型不到 range 級別: select * from orders where order_date > '2022-01-01'; 在這個查詢語句中,如果 orders 表的 order_date 字段沒有創建索引,MySQL 就會對該字段進行全表掃描,從而導致查詢效率低下。 為了避免這種情況,我們可以在 order_date 字段上創建索引,將查詢類型從全表掃描變為范圍查詢,從而提高查詢效率。 聯合索引是由多個列組成的索引,可以在多個列上進行查詢,它同時包含了多個列的索引,多個列組合成一個鍵來進行索引。 相較于單列索引,聯合索引可以提高查詢效率和優化數據庫性能。 聯合索引的好處 聯合索引可以減少磁盤 I/O 操作,提高查詢效率,減少系統負載。
創建和使用聯合索引時,需要特別注意以下幾點:
如果聯合索引使用不當,將導致查詢效率降低、占用過多的磁盤空間、更新數據時效率低下等問題。 聯合索引的使用示例 我們假設有一個用戶表,包含用戶 ID、用戶名和電子郵件地址三個列,我們想要按照用戶名和電子郵件地址進行查詢,可以創建以下聯合索引: create INDEX idx_username_email ON users(username, email); 接著,再執行以下查詢: select * from users where email = 'test@example.com'; 這個查詢雖然可以使用到 idx_username_email 索引,但是它并不會很快,因為 email 列排在了索引的第二個位置,查詢時需要先按照用戶名進行排序,然后再根據電子郵件地址進行過濾,而這個過程可能需要耗費大量的時間。 正確的做法是將 email 列放在第一個位置: create INDEX idx_email_username ON users(email, username); 這樣,查詢時就可以直接使用索引來過濾電子郵件地址了,而不需要再按照用戶名進行排序,極大地提高了查詢性能。 總結本文總結了 SQL 查詢性能優化的一些經驗和注意事項,包括禁止使用 select * 、用小表驅動大表、join 關聯表不宜過多、禁止使用左模糊或者全模糊查詢、索引訪問類型至少達到 range 級別、更優雅的使用聯合索引等。 在實際應用過程中,要結合具體情況靈活運用,以滿足不同的業務需求和應用場景。 該文章在 2023/5/15 21:29:27 編輯過 |
關鍵字查詢
相關文章
正在查詢... |