求一个 sql 拼接的问题 ??
程序员文章站
2022-04-04 22:34:32
...
sql 拼接问题 ? 需求:根据省份,客户名称,通气时间这3个条件去排序,可以只选择一个,也可多个,这3个排序条件都是复选框,
sql 如下:
$MYSQL->query("select * from customer cu " .$where);
排序条件:
省份
客户名称
通气时间
在 sql 后面拼接的排序条件
if($sel_key10){
$where=$where." order by cu.province "; // 省
}
if($sel_key11){
$where .= " ,cu.KFName"; // 客户名称
}
if($sel_key12){
$where .= " ,cu.GiveGasTime "; // 通气时间
}
我这样拼接的是有问题的,如果 单独以省作为排序条件是没有问题的,但是我单独以其他的作为条件,就不对了,如果我同时以2个,或3个,按照,省,客户名称,通气时间,这样的顺序也是对的,
其实我要的sql 就是 :
select * from customer cu where 1=1 order by cu.province,cu.KFName,cu.GiveGasTime ,如果没有条件就不要 order by ,有就在 括号里面追加。。
排序条件:省份 客户名称 通气时间
容易产生sql注入漏洞, 慎用
sql 如下:
$MYSQL->query("select * from customer cu " .$where);
排序条件:
省份
客户名称
通气时间
在 sql 后面拼接的排序条件
if($sel_key10){
$where=$where." order by cu.province "; // 省
}
if($sel_key11){
$where .= " ,cu.KFName"; // 客户名称
}
if($sel_key12){
$where .= " ,cu.GiveGasTime "; // 通气时间
}
我这样拼接的是有问题的,如果 单独以省作为排序条件是没有问题的,但是我单独以其他的作为条件,就不对了,如果我同时以2个,或3个,按照,省,客户名称,通气时间,这样的顺序也是对的,
其实我要的sql 就是 :
select * from customer cu where 1=1 order by cu.province,cu.KFName,cu.GiveGasTime ,如果没有条件就不要 order by ,有就在 括号里面追加。。
排序条件:省份 客户名称 通气时间
回复讨论(解决方案)
可以这么写
$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) : '');
测试代码
'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;如果改造一下表单,处理起来更简单
如果改造一下表单,处理起来更简单
容易产生sql注入漏洞, 慎用
#1 ,#2 ,的方法都没成功, #3 版主的方法成功了。谢谢。
推荐阅读
-
如果你有一个代码出有关问题就把有关问题退给你的领导你该如何做
-
select-mysql 嵌套查询,一个表的多个字段 作为另一个表的条件,求高手
-
php和有关sql seve数据库的有关问题
-
不太懂php,问一个关于wordpress的问题
-
关于mysql的sql注入问题
-
max()-问一个sql问题,hour()获取日期的小时,然后给他赋值最大值,但是为什么出错了
-
php如何将查询到的多条数据拼接成一个文本变量?
-
drupal输出一个用户名的问题 用drupal的主题函数theme输出_PHP教程
-
Mysql 导入SQL脚本乱码的有关问题
-
删除目录及其下的文件还有问题吗?送大家一个写好的函数_PHP教程