Heim >Backend-Entwicklung >PHP-Tutorial >求一个 sql 拼接的问题 ??
sql 拼接问题 ?
需求:根据省份,客户名称,通气时间这3个条件去排序,可以只选择一个,也可多个,这3个排序条件都是复选框, 可以这么写
$where = array();if($sel_key10){$where[] =" cu.province "; // 省}if($sel_key11){$where[] =" cu.KFName"; // 客户名称}if($sel_key12){$where[] = " cu.GiveGasTime "; // 通气时间 }$MYSQL->query("select * from customer cu " . (!empty($where) ? 'order by '. implode(',',$where) : '');
测试代码
<form method=post><input type="checkbox" name="sel_key10" />省份<input type="checkbox" name="sel_key11" />客户名称<input type="checkbox" name="sel_key12" />通气时间<input type=submit></form><?php$dict = array( 'sel_key10' => 'cu.province', // 省 'sel_key11' => 'cu.KFName', // 客户名称 'sel_key12' => 'cu.GiveGasTime', // 通气时间 );$sql = "select * from customer cu ";if($_POST) { $t = array_intersect_key($dict, $_POST); if($t) $sql .= 'order by ' . join(', ', $t);}echo $sql;
如果改造一下表单,处理起来更简单
<form method=post><input type="checkbox" name="o[]" value="cu.province" />省份<input type="checkbox" name="o[]" value="cu.KFName" />客户名称<input type="checkbox" name="o[]" value="cu.GiveGasTime" />通气时间<input type=submit></form><?php$sql = "select * from customer cu ";if(isset($_POST['o'])) { $sql .= 'order by ' . join(', ', $_POST['o']);}echo $sql;
如果改造一下表单,处理起来更简单
<form method=post><input type="checkbox" name="o[]" value="cu.province" />省份<input type="checkbox" name="o[]" value="cu.KFName" />客户名称<input type="checkbox" name="o[]" value="cu.GiveGasTime" />通气时间<input type=submit></form><?php$sql = "select * from customer cu ";if(isset($_POST['o'])) { $sql .= 'order by ' . join(', ', $_POST['o']);}echo $sql;
#1 ,#2 ,的方法都没成功, #3 版主的方法成功了。谢谢。