PHP 模糊搜索

原创 2016年05月30日 10:28:05

Ques:

        项目中需要有模糊搜索功能

解决方案:sql like 和正则

        首先想到的是使用sql的模糊搜索

        查找相关的知识,得以下注意事项:

             1.使用sql匹配模式,不能使用操作符=或!=,而是使用操作符LIKE或NOT LIKE;

             2.使用sql匹配模式,MYSQL提供了2种通配符。%表示任意数量的任意字符(其中包括0个)_表示任意单个字符

             3.使用sql匹配模式,如果匹配格式中不包含以上2种通配符中的任意一个,其查询的效果等同于=或!=

             4.使用sql匹配模式,不区分大小写

             实例中,如果使用like "xxx%" 则可使用到索引,但是如果前后都是模糊匹配,使用select * from tableA from content like "%xxx%" 那么索引是无法生效的。很多文章中,引入了全文索引(据说百万级才用)。也就是说,在没有索引的支持情况下,此时的like的效率是比较低的

/*******************************************************************************************************************************************************************************/

            全文索引,简要说明,只有MyISAM引擎支持全文检索(full text index),查询效率高。但是有局限,不支持事务和外键。Innodb支持事务和外键,但是不支持全文检索。所以,如果需要全文检索的数据,需要使用MyISAM引擎创建表。另外,还有“无效词;分词”的相关概念。

            http://www.365mini.com/page/mysql-create-fulltext-index.htm

            http://www.jb51.net/article/37738.htm

            http://blog.sina.com.cn/s/blog_64589b110101c31a.html

            http://www.cnblogs.com/bourneli/archive/2012/08/09/2630753.html

后续再研究

/*******************************************************************************************************************************************************************************/

        除了sql上的处理方案,也可以使用正则通配符的方式来处理

        #查询用户名以字符 l开头的用户:^l;
       SELECT * FROM user WHERE username REGEXP '^l';
       #查询用户名正好是三个字符的用户:^...$;
        SELECT * FROM user WHERE username REGEXP '^...$';

正则的匹配模式,很容易出现,匹配量超过预期的情况。

        

           




PHP 中文分词 类百度模糊搜索

测试过程中搜索"汉白玉拖鞋" 显示了几款拖鞋,以及一款汉白玉产品. 网上找了一个分词的词库 又找了一个MYSQL的全文搜索方法(把中文转成数字) 具体实现到是很简...
  • bluehire
  • bluehire
  • 2014年01月16日 17:43
  • 1170

php 数组模糊查询

一个数组中有多个值,现在需要输入某个字符传
  • qq_22327455
  • qq_22327455
  • 2014年11月17日 11:59
  • 2749

PHP模糊查询

模式查询 1. SQL匹配模式 2. 正则表达式匹配模式(一般不推荐使用)SQL匹配模式1.使用sql匹配模式,不能使用操作符=或!=,而是使用操作符LIKE或NOT LIKE; 2.使用s...
  • liuzp111
  • liuzp111
  • 2016年05月11日 19:37
  • 679

php中简单模糊查询的sql语句

从topics表中查询字段subject与传进来的参数'$_POST['topic']进行比较模糊查询设subject字段数据为:数学,英语,物理,化学,英文$subject=$_POST['topi...
  • tuoer321
  • tuoer321
  • 2011年03月26日 15:44
  • 20630

php模糊查询实例代码

php模糊查询实例代码参考
  • hky_php
  • hky_php
  • 2015年09月24日 16:29
  • 5562

PHP实现模糊搜索中文分词

1.下面代码复制到公共函数累里面 /** * 模糊搜索中文分词 */ function decorateSearch_pre($words) { $tempArr = str_split(...
  • a403852386
  • a403852386
  • 2017年08月23日 11:43
  • 89

php mongoDB模糊搜索

使用 正则 $query['name']=new MongoRegex("/$search_string/i");
  • qq_35617617
  • qq_35617617
  • 2018年01月23日 10:15
  • 15

PHP中的多条件模糊查询

//获取查询条件       $wherelist = array();   if(!empty($_POST['title'])){      $wherelist[] = "ti...
  • qq_35235794
  • qq_35235794
  • 2017年03月30日 22:39
  • 252

百度地图、高德地图的定位,搜索,模糊搜索 - 2

有了百度地图的经验,相对来说,使用高德SDK 就没有这么晕头转向的,但是在集成的时候,还是遇到了几个问题 问题1:手动导入SDK后,运行的时候发现AMap.bundle导入不成功,其实AMap.bu...
  • code_liujun
  • code_liujun
  • 2016年01月18日 09:19
  • 1166

jquery php 百度搜索框智能提示效果

这个程序是利用php+ajax+jquery 实现的一个仿baidu智能提示的效果,有需要的朋友可以下载测试哦。 先来看看效果代码如下index html文件,保保存成index htm 代码如下复制...
  • u011986449
  • u011986449
  • 2014年10月16日 22:51
  • 2098
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:PHP 模糊搜索
举报原因:
原因补充:

(最多只允许输入30个字)