thinkPHP实现多字段模糊匹配查询的方法

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

本文实例讲述了thinkPHP实现多字段模糊匹配查询的方法。分享给大家供大家参考,具体如下:

引言:有时候查询要匹配多个字段。比如查询地址,地址是由多个字段组成的。有省、市、区等等,以及详细地址。这个时候如何查询呢?

实现不同字段相同的查询条件


    $User = M("User"); // 实例化User对象
    $map['name|title'] = 'thinkphp';
    // 把查询条件传入查询方法
    $User->where($map)->select();

用到项目中


    if ($address) {
      // 地址查询
      $where['b.province|b.city|b.area|b.detail'] = array('like', '%'.$address.'%');
            $this->assign('address', $address);
    }

这里就很简单的解决了这个需求,而且很精准。

生成的sql语句如下


    SELECT a.*,b.name,b.tel,b.province,b.city,b.area,b.detail,b.zipcode
    FROM sh_order a
    LEFT JOIN sh_member_address b on a.member_id = b.member_id and b.selected = 1
    WHERE ( `store_id` = '10' ) AND ( a.member_id IN ('7') ) AND ( (b.province LIKE '%宿城区%') OR (b.city LIKE '%宿城区%') OR (b.area LIKE '%宿城区%') OR (b.detail LIKE '%宿城区%') )
    ORDER BY addtime desc, sendtime asc, paytime desc
    LIMIT 0,10

从sql语句中可以看出,where中的括号,AND,OR组合的很巧妙。

截图如下

更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》、《smarty模板入门基础教程》及《PHP模板技术总结》。

希望本文所述对大家基于ThinkPHP框架的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分页类完整实例