MySQL数据库中文模糊检索问题的方法

2018-11-20 03:19:45来源:爱站网 阅读 ()

新老客户大回馈,云服务器低至5折

  MySQL数据库中文模糊检索问题的方法,MySQL下,在进行中文模糊检索时,经常会返回一些与之不相关的记录,如查找?"%a%"?时,返回的可能有中文字符,却没有a字符存在。本人以前也曾遇到过类似问题,经详细阅读MySQL的Manual,发现可以有一种方法很方便的解决并得到满意的结果。

  希望通过“标题”对新闻库进行检索,关键字可能包含是中英文,如下SQL语句:

  以下为引用的内容:


  
Code:
select?id,title,name?from?achech_com.news?where?title?like?'%a%'


  返回的结果,某些title字段确定带了“a”关键字,而有些则只有中文,但也随之返回在检索结果中。

  解决方法,使用?BINARY?属性进行检索,如:

  以下为引用的内容:


  
Code:
select?id,title,name?from?achech_com.news?where?binary?title?like?'%a%'


  返回的结果较之前正确,但英文字母区分大小写,故有时在检索如“Achech”及“achech”的结果是不一样的。知道了使用?BINARY?属性可以解决前面这个问题,再看看?MySQL?支持的UCASE?及?CONCAT?函数,其中?UCASE?是将英文全部转成大写,而CONCAT函数的作用是对字符进行连接,以下是我们完全解决后的SQL?语句:


  
Code:
select?id,title,name?from?achech_com.news

  where?binary?ucase(title)?like?concat('%',ucase('a'),'%')

  检索的步骤是先将属性指定为?BINARY?,以精确检索结果,而被?like?的?title内容存在大小写字母的可能,故先使用?ucase?函数将字段内容全部转换成大写字母,然后再进行?like?操作,而?like?的操作使用模糊方法,使用?concat的好处是传进来的可以是直接的关键字,不需要带“%”万用符,将“'a'”直接换成你的变量,在任何语言下都万事无忧了。?当然你也可以这么写:


  
Code:
select?id,title,name?from?achech_com.news?where?binary?ucase(title)?like?ucase('%a%')


  检索的结果还算满意吧,不过速度可能会因此而慢N毫秒。

  以上就是MySQL数据库中文模糊检索问题的方法,如果还有其它疑问,欢迎补充,有任何问题也可以与爱站编辑一起讨论。

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:浅析MySQL的数据类型和建库策略

下一篇:MySQL常用语法及其使用指南分享