MySQL数据库中文模糊检索问题的方法
2018-11-20 03:19:45来源:爱站网 阅读 ()
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 replace函数怎么替换字符串语句 2020-03-09
- PHP访问MySQL查询超时怎么办 2020-03-09
- mysql登录时闪退 2020-02-27
- MySQL出现1067错误号 2020-02-27
- mysql7.x如何单独安装mysql 2020-02-27
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash