閱讀247 返回首頁    go 阿裏雲 go 技術社區[雲棲]


SQL語句中where 1=1的基本用法

剛才有一位網友說了本文的不足,我再此重新編輯重發一篇整理過的,希望多提意見。

 

與where 1=1等效的類似語句有1<>2,'a'='a','a'<>'b',其目的是where的條件為永真,得到的結果就是未加約束條件的。那麼where 1=1 有什麼用處呢?


使用一 拚接SQL語句

 

一個簡單拚接SQL語句的例子:

String sql = select * from table student where 1=1;
StringBuffer buffer = new StringBuffer();
buffer.append(sql);

if (null != name && !"".equals(name)) {
 buffer.append("and name = " + name);
}

if (null != phone && !"".equals(phone)) {
 buffer.append("and phone like '" + phone + "'");
}

ibatis中的動態語句的拚接與其原理相似,也可以加1=1。

 

若不使用1=1,拚接會有多麻煩呢?String sql = select * from table student where;這個語句還在,那麼如果三個條件都是空呢?where就是光禿禿了。再設想,若一個空,一個不空或者兩個都不空,拚接的語句就不一樣了。這隻是兩個條件,要是更多的條件呢?體會到1=1的用處了吧。我們可以發現 or 1 = 1拚在後麵可以恒使條件成立。

 

使用二 拷貝表或複製表結構

拷貝表
create student_bak as select * from student where 1=1;

複製表結構
create student_bak as select * from student where 1<>1;

 

參考博客:https://www.accessoft.com/article-show.asp?id=6912

最後更新:2017-04-03 20:19:44

  上一篇:go oracle中is null到底判斷的是什麼
  下一篇:go 代碼之謎 - 其實,你不懂代碼