SQL Server源碼中常見(jiàn)的 where 1=1 是一種高級(jí)優(yōu)化技巧?
當(dāng)前位置:點(diǎn)晴教程→知識(shí)管理交流
→『 技術(shù)文檔交流 』
你是否曾在 此外,由于查詢(xún)優(yōu)化器幾乎肯定會(huì)刪除它,因此對(duì)查詢(xún)執(zhí)行時(shí)間沒(méi)有影響。那么, where 1=1 會(huì)改善查詢(xún)執(zhí)行嗎?正如前文中所述,我們預(yù)計(jì)查詢(xún)優(yōu)化器會(huì)刪除硬編碼的 首先,以下是在 Sakila 示例數(shù)據(jù)庫(kù)運(yùn)行的查詢(xún),獲取從 Lethbridge 商店租借電影的客戶(hù): 在信息選項(xiàng)卡的底部可以看到 0.004 秒的運(yùn)行時(shí)間(用紅色方框突出顯示)。 現(xiàn)在,讓我們運(yùn)行相同的查詢(xún),但添加了 同樣,運(yùn)行時(shí)間為 0.004 秒。盡管查詢(xún)的運(yùn)行時(shí)間可能因許多因素會(huì)略有波動(dòng),但可以肯定地說(shuō)
為方便而設(shè)事實(shí)上, 在靜態(tài) SQL 中向已經(jīng)具有 where 1=1 的查詢(xún)添加條件時(shí),此后的所有條件都將包含 AND,因此在注釋掉試驗(yàn)查詢(xún)的條件時(shí)更容易。 這類(lèi)似于另一種在列名之前而不是之后加入逗號(hào)的技巧。同樣,更容易注釋?zhuān)?/p> 在動(dòng)態(tài) SQL 中這也是以編程方式構(gòu)建 SQL 查詢(xún)時(shí)的常見(jiàn)做法。從“
總結(jié)在這篇文章中,我們了解到“ 該文章在 2023/3/24 17:23:58 編輯過(guò) |
關(guān)鍵字查詢(xún)
相關(guān)文章
正在查詢(xún)... |