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

SQL Server源碼中常見(jiàn)的 where 1=1 是一種高級(jí)優(yōu)化技巧?

admin
2023年3月24日 17:23 本文熱度 899

你是否曾在 select 查詢(xún)中看到過(guò) where 1=1 條件。我在許多不同的查詢(xún)和許多 SQL 引擎中都有看過(guò)。這條件顯然意味著 where TRUE,所以它只是返回與沒(méi)有 where 子句時(shí)相同的查詢(xún)結(jié)果。

此外,由于查詢(xún)優(yōu)化器幾乎肯定會(huì)刪除它,因此對(duì)查詢(xún)執(zhí)行時(shí)間沒(méi)有影響。那么,where 1=1 的作用是什么?這就是我們今天要在這里回答的問(wèn)題!

where 1=1 會(huì)改善查詢(xún)執(zhí)行嗎?

正如前文中所述,我們預(yù)計(jì)查詢(xún)優(yōu)化器會(huì)刪除硬編碼的 where 1=1 子句,因此我們不應(yīng)看到查詢(xún)執(zhí)行時(shí)間減少。為了證實(shí)這個(gè)假設(shè),讓我們?cè)?Navicat 中運(yùn)行一個(gè)有和一個(gè)無(wú) where 1=1 子句的 select 查詢(xún)。

首先,以下是在 Sakila 示例數(shù)據(jù)庫(kù)運(yùn)行的查詢(xún),獲取從 Lethbridge 商店租借電影的客戶(hù):

在信息選項(xiàng)卡的底部可以看到 0.004 秒的運(yùn)行時(shí)間(用紅色方框突出顯示)。

現(xiàn)在,讓我們運(yùn)行相同的查詢(xún),但添加了 where 1=1 子句:

同樣,運(yùn)行時(shí)間為 0.004 秒。盡管查詢(xún)的運(yùn)行時(shí)間可能因許多因素會(huì)略有波動(dòng),但可以肯定地說(shuō) where 1=1 子句對(duì)其沒(méi)有任何影響。

那么,為什么要使用它呢?簡(jiǎn)單來(lái)說(shuō),就是...

為方便而設(shè)

事實(shí)上,where 1=1 子句只是一些開(kāi)發(fā)人員采用的一種慣性做法,以簡(jiǎn)化靜態(tài)和動(dòng)態(tài)形式的 SQL 語(yǔ)句的使用。

在靜態(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)做法。從“where 1=1”開(kāi)始,然后附加其他條件,例如“ and customer.id=:custId”,具體取決于是否提供了客戶(hù) ID。這允許開(kāi)發(fā)人員在查詢(xún)中附加以“and ...”開(kāi)頭的下一個(gè)條件。這是一個(gè)假設(shè)的例子:

stmt  = "select * "
stmt += "
from TABLE "
stmt += "
where 1=1 "
if user chooses option a then stmt += "
and A is not null "
if user chooses option b then stmt += "
and B is not null "
if user chooses option b then stmt += "
and C is not null "
if user chooses option b then stmt += "
and D is not null "

總結(jié)

在這篇文章中,我們了解到“where 1=1 的目的是什么?”這個(gè)古老問(wèn)題的答案。它不是一種高級(jí)優(yōu)化技巧,而是一些開(kāi)發(fā)人員所主張的一種風(fēng)格慣例。



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

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
在线看片免费人成视频丨 | 亚洲一区二区在线AⅤ | 日韩1区2区3区蜜桃在线观看 | 中文字幕亚洲一区婷婷 | 热久久美女精品天天吊色 | 午夜福利久久野草 |