PHP 搜索查询功能实现

5年以前  |  阅读数:1186 次  |  编程语言:PHP 

今天遇到一个问题:在做"搜索"功能时,输入查询条件后查询不了。

我做的是首页显示数据表package中的内容,但是有个条件,显示在首页的内容还必须是 :字段status=0,且printing=0的数据才能在首页列表中显示出来。

页面上有一个"搜索"功能,输入条件后就会根据条件来进行查询。

一般的搜索的话,只要在首页显示列表方法index()中给一个:


    $map=array();//初始化查询条件
    $map=$this->_search();//调用查询方法
    $total = $this->Model->where ($map)->count(); //这个主要是用来计算页面显示数据条数的
    if ($total == 0) {
    $_list = '';
    } else {
    $_list = $this->Model->where ($map)->limit( $post_data ['first'] . ',' . $post_data ['rows'] )->select();
    }

然后,就是写一个_search():

如:


    protected function _search(){
    $map = array ();
    $post_data = I ( 'post.' );
    if ($post_data ['packageid'] != '') {
    $map ['packageid'] = array (
    'like',
    '%' . $post_data ['packageid'] . '%' 
    );
    }
    return $map;
    }

最后,在设置的"搜索"菜单中,调用这个搜索方法。

但是,我做的这个,搜索的同时,还要确保在字段status=0,且printing=0的数据中进行搜索。

我一直在想这个限制条件该加在什么地方。各种尝试和查询后,才知道。限制条件直接加在SQL语句中就行了(如下红色的地方)。(我自己试的时候一直在如下蓝色的地方加条件,屡试屡败!)


    $map=array();
    $map=$this->_search();
    $total = $this->Model->where ($map)->where(array('status' =>0,'print_status'=>0))->count();
    if ($total == 0) {
    $_list = '';
    } else {
    $_list = $this->Model->where ($map)->where(array('status' =>0,'print_status'=>0))->limit( $post_data ['first'] . ',' . $post_data ['rows'] )->select();
    }

以上所述是小编给大家介绍的PHP 搜索查询功能实现,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例