您现在的位置是:首页 > 技术交流技术交流
hinkPHP框架模糊查询’DB_LIKE_FIELDS’设置无效的bug
2017-04-24【技术交流】2113 人已围观
简介手册表达式查询like项提示:如果配置了DB_LIKE_FIELDS参数的话,某些字段也会自动进行模糊查询。设置以后无效,原因如下: ...
手册表达式查询like项提示:如果配置了DB_LIKE_FIELDS参数的话,某些字段也会自动进行模糊查询。设置以后无效,原因如下:
Driver.class.php第526行
$whereStr .= $this->parseWhereItem($this->parseKey($key),$val);//第526行
parseWhereItem()方法的第一个参数进行了解析,$key被加了 ,也就是\"title\"变成了\"title\"(title为示例),导致第598行返回0
if($likeFields && preg_match(\'/^(\'.$likeFields.\')$/i\',$key)) //第598行,
也就是preg_match(\'/^(title)$/i\',\'title\')==0
解决办法,加 ,修改源码为:
if($likeFields && preg_match(\'/^(\'.$likeFields.\')$/i\',$key))
修改后再配置
\'DB_LIKE_FIELDS\' OK.
\'DB_LIKE_FIELDS\'=\'title\',
$map[\'title\']=\'thinkphp\';
$result=M(xxx)->where($map)->select();
关注宁波网站建设博客,更多精彩分享,敬请期待!
Driver.class.php第526行
$whereStr .= $this->parseWhereItem($this->parseKey($key),$val);//第526行
parseWhereItem()方法的第一个参数进行了解析,$key被加了 ,也就是\"title\"变成了\"title\"(title为示例),导致第598行返回0
if($likeFields && preg_match(\'/^(\'.$likeFields.\')$/i\',$key)) //第598行,
也就是preg_match(\'/^(title)$/i\',\'title\')==0
解决办法,加 ,修改源码为:
if($likeFields && preg_match(\'/^(\'.$likeFields.\')$/i\',$key))
修改后再配置
\'DB_LIKE_FIELDS\' OK.
\'DB_LIKE_FIELDS\'=\'title\',
$map[\'title\']=\'thinkphp\';
$result=M(xxx)->where($map)->select();
查询条件就不是 title=\'thinkphp\',而是 title like \'%thinkphp%\'.
这个上参数的配置,简单的来说就是把原本等于号起来的查询条件变成like模糊查询. 我个人感觉可有可无的设置
关注宁波网站建设博客,更多精彩分享,敬请期待!
Tags:
很赞哦! ()
相关文章
随机图文
mysql查询今天,昨天,近7天,近30天,本月,上一月数据的方法
MySQL查询今天,昨天,近7天,近30天,本月,上一月数据的方法分析总结:(这篇文章 看到后我仿佛又是看到了新窗户,眼前一亮)mysql还...dedecms5.7生成文件时提示“模板文件不存在,无法解析”的解决方法
dedecms是一个非常经典的cms系统,并且开源很多做网站的人都喜欢用他,那么在网站生成文件的时候,出现错误提示“模板文件不存在,无法解析...js jquery新打开窗口与新开标签页
在项目中我们设置了一个网友点击下载提示输入邮箱的功能, 如果输入的邮箱正确格式就可以下载样本,这是需要新开窗口而不是把原窗口给关闭了.这...linux显示当前版本
有时接手维护一下linux服务器,我们第一步需要确定当前版本,以下命令可以尝试 先以root登陆1、# uname -a (Linux查看...