文档章节

php多条件筛选查询拼接技巧

高处胜寒
 高处胜寒
发布于 2017/06/03 14:34
字数 381
阅读 32
收藏 0
$query = [];
$valid=['type', 'area', 'year', 'person']; // 有效的查询Key:类型/地区/年代/明星
foreach($_GET AS $queryName) {
// 查询全部时,直接忽略该条件
if(($_GET[$queryName] !== 'all') && in_array($queryName,$valid)){
$query[$queryName] = $_GET[$queryName];
}
}
$where = count($query) ? 'WHERE '.implode(',', $query) : '';
$result = $db->query("SELECT * FROM tableName {$where}");
//注释1-----------------------------
$depart=$_POST["depart"];
$ename=$_POST["ename"];
//注释2------------------------
if($depart != null){
$a = " and depart like '%$depart%'";}
if($ename != null){
$b = " and ename like '%$ename%'";}
//注释3------------------------
$q = "SELECT * FROM info where (1=1)";
$q .=$a;
$q .=$b;
$where="where 1 ";

$days=$_GET['days'];
$types=$_GET['types'];

if(is_numeric($days) && $days>0){
$where.="and days=$days ";
}

if(!empty($types)){
$where.="and types='$types' ";
}

$model=new Model();//创建数据库操作模型
$result=$model->query("select * from blog $where");
$sqlexp='';
//下面开始组根据用户设置的查询条件进行SQL查询条件的组装

if(!empty($price)) {
    $sqlexp.=' and (price>='.$price_arr[0].' and price<='.$price_arr[1];

}
if(!empty($brandid)) {
   $sqlexp.=' and brandid='.$brandid;
}
if(!empty($productname)) {
   $sqlexp.=" and instr(productname,'$productname')>0";
}

//下面执行SQL查询

$result=mysql_query("select * from product where state=1 ".$sqlexp);

在上面的查询完成后,把查询结果返回给用户,就完成了用户按条件筛选商品的功能。
// $q = ["typeid" =>2,"ismake"=>1,"channel"=>1];
$q = Request::instance()->except(['page', 'sub'], 'get');;

$pageParam = ['query' => []];


if (!empty($q["typeid"])) {
    $pageParam['query']['typeid'] = $q["typeid"];
}


if (!empty($q["ismake"])) {
    $pageParam['query']['ismake'] = $q["ismake"];
}

if (!empty($q["channel"])) {
    $pageParam['query']['channel'] = $q["channel"];
}


$q = $pageParam['query'];


dump($pageParam['query']);


// $data =  Db::query('select * from dede_archives');
$test = Db::connect("db_config2")->table('dede_archives')->fetchSql(true)->where($q)->select();

$list = Db::connect("db_config2")->table('dede_archives')->where($q)->paginate(5, false, [
    'type' => 'bootstrap',
    'var_page' => 'page',
    // 'fragment' => 'maodian',
    // 'page' => '111',
    // 'path' =>'ccc',
    'query' => $q,
]);

echo $test;

$page = $list->render();
// 模板变量赋值
$this->assign('list', $list);
$this->assign('page', $page);
// 渲染模板输出
return $this->fetch();

© 著作权归作者所有

共有 人打赏支持
高处胜寒
粉丝 7
博文 195
码字总数 145176
作品 0
西安
程序员
私信 提问
Mybatis 中 Oracle 的拼接模糊查询

注意 Mybatis 中,拼接模糊查询的用法 #,是将传入的值当做字符串的形式。所以拼接的时候 #{userName} 默认自带引号。 例如: 直接转为。userName直接转为′zhen′。,是将传入的数据直接显示...

小刀爱编程
10/10
0
0
多个条件进行筛选查询的时候,怎么设计比较好?

php,pdo方式,没用任何框架。这是前提条件,不可改变。 比如,现在只有一张学生表student,包含了所有学生相关信息(id,学号,姓名,班级。。。)。 比如班级筛选,我可以选1班,2班,3班,...

Forsend
2014/10/09
3.6K
7
如何处理大量的筛选条件?

如题,展示数据时,通常有大量的筛选条件,后台应该怎样写以减少工作量?现在有个思路就是拼SQL语句,动态改变SQL语句,例如某个筛选条件的输入框的value为空或是空字符串,就不拼上相应的筛...

Benjaman
2016/08/16
173
4
拼接SQL的一个技巧

为了避免判断是否要在字符串中加 AND 来连接查询条件,我们可以直接在在WHERE 后面写id>0。这样,我们在拼接条件的时候,就可以直接写 AND 了。

周田
2016/04/08
163
4
再提LBS经纬度搜索和距离排序,求更优方案

再提LBS经纬度搜索和距离排序,求更优方案 1赞踩收藏 一直在琢磨LBS,期待可以发现更好的方案。现在纠结了。 简单列举一下已经了解到的方案: 1.sphinx geo索引 2.mongodb geo索引 3.MySQL ...

飓风2000
2016/08/04
40
1

没有更多内容

加载失败,请刷新页面

加载更多

Linux 设备驱动--- 阻塞型字符设备驱动 --- O_NONBLOCK --- 非阻塞标志

阻塞: 在设计简单字符驱动程序时,要注意一个重要问题. 当一个设备无法立刻满足用户的读写请求时应当如何处理? 例如:调用 read 时没有数据可读,但以后可能会有; 或者一个进程试图向设备写...

天王盖地虎626
11分钟前
0
0
作用域、作用域链精解

首先来几个名词解释: 作用域[scope]:每一个js函数都是一个对象,对象中有些属性我们可以访问,但有些不可以,这些属性仅供js引擎存取,[[scope]]就是对象其中一个属性。[[scope]]指的就是我...

IrisHuang
12分钟前
0
0
etcd集群备份和数据恢复

etcd是一个分布式k-v数据库,在kubernetes中使用其管理集群的元数据。这里介绍etcd集群数据的备份和数据恢复的方法和步骤。 本文来自于:https://www.maideliang.com/index.php/archives/25/...

openthings
26分钟前
1
0
「阿里面试系列」面试加分项,从JVM层面了解线程的启动和停止

文章简介 这一篇主要围绕线程状态控制相关的操作分析线程的原理,比如线程的中断,线程的通信等,内容比较多,可能会分两篇文章 阿里面试系列导读:关注我的技术公众号【架构师修炼宝典】一周...

Java架构资源分享
33分钟前
4
0
centos安装confluence全攻略

https://blog.csdn.net/qwer026/article/details/51439076

happyeveryday32
46分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部