天天看點

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;

參考部落格:http://www.accessoft.com/article-show.asp?id=6912