sql中对于传过来的空值判断 我有四个这样的输入值 action到处理的php页面 有没有什么方法能够合理的让php页面的sql语句判断当那个字段为空时,就不以那个为搜索的条件了 除了穷举,还有什么方法? $sql="select * from table where ..."
实例: html
chuli.php //连接数据库部分省略 $sql="select * from student where name='$name' and age='$age' and sex='$sex' and height='$height';// 这个是所有的 $result = mysql_query($sql,$con);
foreach(array_diff($_POST, array('')) as $k=>$v)
$r[] = "$k='$v'";
$sql = "select * from student where ". join(' and ', $r);
------解决方案-------------------- 应该是,上面少给一个''
PHP code
$sql="select * from student where 1=1";
if(!empty($_POST['name'])) $sql=" and name='$_POST[name]'";
if(!empty($_POST['age'])) $sql=" and age='$_POST[age]'";
if(!empty($_POST['sex'])) $sql=" and sex='$_POST[sex]'";
if(!empty($_POST['height'])) $sql=" and height='$_POST[height]'";