sql中的where 1=1妙用

  1. 主要是为了便于动态连接后续条件,即使后面的查询条件都为空都可以查询,还有就是避免后面是and而出错。
  2. where 1=1有什么用?在SQL语言中,写这么一句话就跟没写一样。     
  3. select * from table1 where 1=1与select * from table1完全没有区别,甚至还有其他许多写法,1<>2'a'='a','a'<>'b',其目的就只有一个,where的条件为永真,得到的结果就是未加约束条件的。     
  4. 在SQL注入时会用到这个,例如select * from table1 where name='lala'给强行加上select * from table1 where name='lala' or 1=1这就又变成了无约束的查询了。     
  5. 最近发现的妙用在于,在不定数量查询条件情况下,1=1可以很方便的规范语句。例如一个查询可能有name,age,height,weight约束,也可能没有,那该如何处理呢?     
  6. String sql=select * from table1 where 1=1  什么要写多余的1=1?马上就知道了。    
  7. if(!name.equals("")){   
  8. sql=sql+"name='"+name+"'";   
  9. }   
  10. if(!age.equals("")){   
  11. sql=sql+"age'"+age+"'";   
  12. }   
  13. if(!height.equals("")){   
  14. sql=sql+"height='"+height+"'";   
  15. }   
  16. if(!weight.equals("")){   
  17. sql=sql+"weight='"+weight+"'";   
  18. }     
  19. 如果不写1=1呢,那么在每一个不为空的查询条件面前,都必须判断有没有where字句,否则要在第一个出现的地方加where   
  20. 今天看到:"SELECT * FROM strName WHERE 1 = 0";   
  21. 不理解为什么有1=0?     
  22. 查询得出答案:     
  23. 该select语句主要用于读取表的结构而不考虑表中的数据,这样节省了内存,因为可以不用保存结果集。   
  24. 另外,这个用在什么地方呢?主要用于创建一个新表,而新表的结构与查询的表的结构是一样的。如下SQL语句:     
  25. create table newtable as select * from oldtable where 1=0;  
posted @ 2010-09-15 16:58  anny0320  阅读(773)  评论(0编辑  收藏  举报