廊坊網(wǎng)站快速排名優(yōu)化杭州seo營(yíng)銷
你是否曾在 SELECT 查詢中看到過 WHERE 1=1 條件。我在許多不同的查詢和許多 SQL 引擎中都有看過。這條件顯然意味著 WHERE TRUE,所以它只是返回與沒有 WHERE 子句時(shí)相同的查詢結(jié)果。此外,由于查詢優(yōu)化器幾乎肯定會(huì)刪除它,因此對(duì)查詢執(zhí)行時(shí)間沒有影響。那么,WHERE 1=1 的作用是什么?這就是我們今天要在這里回答的問題!
WHERE 1=1 會(huì)改善查詢執(zhí)行嗎?
正如前文中所述,我們預(yù)計(jì)查詢優(yōu)化器會(huì)刪除硬編碼的 WHERE 1=1 子句,因此我們不應(yīng)看到查詢執(zhí)行時(shí)間減少。為了證實(shí)這個(gè)假設(shè),讓我們?cè)?Navicat 中運(yùn)行一個(gè)有和一個(gè)無 WHERE 1=1 子句的 SELECT 查詢。
首先,以下是在 Sakila 示例數(shù)據(jù)庫運(yùn)行的查詢,獲取從 Lethbridge 商店租借電影的客戶:
在信息選項(xiàng)卡的底部可以看到 0.004 秒的運(yùn)行時(shí)間(用紅色方框突出顯示)。
現(xiàn)在,讓我們運(yùn)行相同的查詢,但添加了 WHERE 1=1 子句:
同樣,運(yùn)行時(shí)間為 0.004 秒。盡管查詢的運(yùn)行時(shí)間可能因許多因素會(huì)略有波動(dòng),但可以肯定地說 WHERE 1=1 子句對(duì)其沒有任何影響。
那么,為什么要使用它呢?簡(jiǎn)單來說,就是...
為方便而設(shè)
事實(shí)上,WHERE 1=1 子句只是一些開發(fā)人員采用的一種慣性做法,以簡(jiǎn)化靜態(tài)和動(dòng)態(tài)形式的 SQL 語句的使用。
在靜態(tài) SQL 中
向已經(jīng)具有 WHERE 1=1 的查詢添加條件時(shí),此后的所有條件都將包含 AND,因此在注釋掉試驗(yàn)查詢的條件時(shí)更容易。
這類似于另一種在列名之前而不是之后加入逗號(hào)的技巧。同樣,更容易注釋:
在動(dòng)態(tài) SQL 中
這也是以編程方式構(gòu)建 SQL 查詢時(shí)的常見做法。從“WHERE 1=1”開始,然后附加其他條件,例如“ and customer.id=:custId”,具體取決于是否提供了客戶 ID。這允許開發(fā)人員在查詢中附加以“and ...”開頭的下一個(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?+=?"
總結(jié)
在這篇文章中,我們了解到“WHERE 1=1 的目的是什么?”這個(gè)古老問題的答案。它不是一種高級(jí)優(yōu)化技巧,而是一些開發(fā)人員所主張的一種風(fēng)格慣例。