剛才有一位網友說了本文的不足,我再此重新編輯重發一篇整理過的,希望多提意見。
與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