转!sql中where 1=1 的使用

2018-09-01  本文已影响0人  caae
在mysql中,where 1=1; 这个条件始终为True,在不定数量查询条件情况下,1=1可以很方便的规范语句。 image

例如为不定数量的查询条件,我们在后台写查询的时候,类似于这样的语句

$sql = "select * from table where";

当条件starttime和endtime都为空时

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的时候

 $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表的所有数据

原文链接:
https://www.cnblogs.com/wangcongsuibi/p/7813445.html

上一篇下一篇

猜你喜欢

热点阅读