LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

SQL優化:如何高效查詢

admin
2025年6月22日 0:23 本文熱度 466

為什么別人的查詢只要幾秒,而你的查詢語句少則十多秒,多則十幾分鐘甚至幾個小時?與你的查詢語句是否高效有很大關系。

今天我們來看看如何寫出比較高效的查詢語句。

  1. 盡量不要使用NULL當默認值

    在有索引的列上如果存在NULL值會使得索引失效,降低查詢速度,該如何優化呢?例如:

    SELECT *  FROM [Sales].[Temp_SalesOrder] 
    WHERE UnitPrice IS NULL

    我們可以將NULL的值設置成0或其他固定數值,這樣保證索引能夠繼續有效。

    SELECT *  FROM [Sales].[Temp_SalesOrder] 
    WHERE UnitPrice =0

    這是改寫后的查詢語句,效率會比上面的快很多。

  2. 盡量不要在WHERE條件語句中使用!=或<>

    在WHERE語句中使用!=或<>也會使得索引失效,進而進行全表掃描,這樣就會花費較長時間了。

  3. 應盡量避免在 WHERE子句中使用 OR

    遇到有OR的情況,我們可以將OR使用UNION ALL來進行改寫

    例如:

    SELECT * FROM T1 WHERE NUM=10 OR NUM=20

    -- 可以改寫成

    SELECT * FROM T1 WHERE NUM=10
    UNION ALL
    SELECT * FROM T1 WHERE NUM=20
  4. IN和NOT IN也要慎用

    遇到連續確切值的時候 ,我們可以使用BETWEEN AND來進行優化

    例如:

    SELECT * FROM T1 WHERE NUM IN (5,6,7,8)
    -- 可以改寫成:
    SELECT * FROM T1 WHERE NUM BETWEEN 5 AND 8.

  5. 子查詢中的IN可以使用EXISTS來代替

    子查詢中經常會使用到IN,如果換成EXISTS做關聯查詢會更快

    例如:

    SELECT * FROM T1 
    WHERE ORDER_ID IN
    (SELECT ORDER_ID FROMORDER
    WHERE PRICE>20);

    -- 可以改寫成:

    SELECT * FROM T1 AS A 
    WHEREEXISTS
    (SELECT1FROMORDERAS B 
    WHERE A.ORDER_ID=B.ORDER_ID AND B.PRICE>20)


    雖然代碼量可能比上面的多一點,但是在使用效果上會優于上面的查詢語句。

  6. 模糊匹配盡量使用后置匹配

    在進行模糊查詢,使用LIKE時盡量使用后置匹配,這樣會走索引,減少查詢時間。

    例如:

    SELECT * FROM T1 WHERENAMELIKE'%李四%'

    -- 或者

    SELECT * FROM T1 WHERENAMELIKE'%李四'

    -- 均不會走索引,只有當如下情況

    SELECT * FROM T1 WHERENAMELIKE'李四%'才會走索引。


上述這些都是平常經常會遇到的,就直接告訴大家怎么操作了,具體可以下去做試驗嘗試一下。

——End——


閱讀原文:原文鏈接


該文章在 2025/6/23 12:52:46 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
欧美视频精品一区二区 | 日本区一视频区二视频 | 偷窥国产亚洲女爱视频在线 | 亚洲无线乱码字幕观看 | 日本一道久久高清国产 | 欧美中日韩国产精品卡通动漫一区二区 |