LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

SQL優(yōu)化:如何高效查詢

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

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

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

  1. 盡量不要使用NULL當(dāng)默認(rèn)值

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

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

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

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

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

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

    在WHERE語句中使用!=或<>也會(huì)使得索引失效,進(jìn)而進(jìn)行全表掃描,這樣就會(huì)花費(fèi)較長時(shí)間了。

  3. 應(yīng)盡量避免在 WHERE子句中使用 OR

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

    例如:

    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也要慎用

    遇到連續(xù)確切值的時(shí)候 ,我們可以使用BETWEEN AND來進(jìn)行優(yōu)化

    例如:

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

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

    子查詢中經(jīng)常會(huì)使用到IN,如果換成EXISTS做關(guān)聯(lián)查詢會(huì)更快

    例如:

    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)


    雖然代碼量可能比上面的多一點(diǎn),但是在使用效果上會(huì)優(yōu)于上面的查詢語句。

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

    在進(jìn)行模糊查詢,使用LIKE時(shí)盡量使用后置匹配,這樣會(huì)走索引,減少查詢時(shí)間。

    例如:

    SELECT * FROM T1 WHERENAMELIKE'%李四%'

    -- 或者

    SELECT * FROM T1 WHERENAMELIKE'%李四'

    -- 均不會(huì)走索引,只有當(dāng)如下情況

    SELECT * FROM T1 WHERENAMELIKE'李四%'才會(huì)走索引。


上述這些都是平常經(jīng)常會(huì)遇到的,就直接告訴大家怎么操作了,具體可以下去做試驗(yàn)嘗試一下。

——End——


閱讀原文:原文鏈接


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

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
一本精品久久精品 | 亚洲中文字无幕码中文字 | 日本在线不卡中文字幕资源 | 一本到在线观看视频 | 亚洲天码中文字幕五月天 | 婷婷丁香五月天永久在线 |