sql中where 1=1 的使用


where 1=1; 这个条件始终为True,在不定数量查询条件情况下,1=1可以很方便的规范语句。

 

例如为不定数量的查询条件,我们在后台写查询的时候,类似于这样的语句 string sql ="select * from table where"

if(starttime!=null){

sql =sql+" starttime="+starttime

if(endtime !=null){

sql =sql+"and endtime ="+endtime

}

这时我们的查询语句就是 select * from table where starttime =2015-04-05 and endtime = 2015-04-07,查询语句正确

但是如果条件都不满足的话,语句就变成了 select * from table where ,这时候查询就会报错,

加上1=1的时候

string sql ="select * from table where 1=1",

if(starttime!=null){

sql =sql+" and  starttime="+starttime

if(endtime !=null){

sql =sql+"and endtime ="+endtime

}

当两个条件成立的时候 select * from table where 1=1 and starttime =2015-04-05 and endtime = 2015-04-07, 语句正确

当两个条件不满足时 select * from table where 1=1 ,语句正确,会返回table表的所有数据


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM