thinkphp中的多字段模糊匹配
2016-03-16 13:51
609 查看
引言:有时候查询要匹配多个字段。比如查询地址,地址是由多个字段组成的。有省、市、区等等,以及详细地址。这个时候如何查询呢?
实现不同字段相同的查询条件
用到项目中
这里就很简单的解决了这个需求,而且很精准。
生成的sql语句如下
从sql语句中可以看出,where中的括号,AND,OR组合的很巧妙。
截图如下
实现不同字段相同的查询条件
$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组合的很巧妙。
截图如下
相关文章推荐
- yii学习点滴
- PHP函数 extract() 将数组中的键值转换为变量
- PHP时间比较和时间差如何计算
- 在windows上新建一个ftp服务器
- strtotime()函数应用
- laravel的编辑器 (未经测试先mark)
- PHP——小尾巴之权限管理
- ubuntu 12.04安装、配置和使用tftp
- PHP编码规范与PSR标准
- thinkphp 3.23语言包加载
- 笔记整理 静态与非静态 继承哪一些 继承链 重写 属性方法重载 PDO
- windows 中使用cmd运行PHP文件
- php 安装扩展
- FTP与SFTP
- sftp命令
- php设计模式
- 五种常见的php设计模式
- php常用图片处理类
- php获取指定目录下的目录及文件
- 小胖学PHP总结1-----PHP的数据类型