中易网

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

答案:1  悬赏:70  
解决时间 2021-10-29 03:39
解决MySQL数据库中文模糊检索问题的方法
最佳答案
在MySQL下,在进行中文模糊检索时,经常会返回一些与之不相关的记录,如查找"%a%"时,返回的可能有中文字符,却没有a字符存在。本人以前也曾遇到过类似问题,经详细阅读MySQL的Manual,发现可以有一种方法很方便的解决并得到满意的结果。   希望通过“标题”对新闻库进行检索,关键字可能包含是中英文,如下SQL语句:   以下为引用的内容:    Code: selectid,title,namefromachech_com.newswheretitlelike'%a%'   返回的结果,某些title字段确定带了“a”关键字,而有些则只有中文,但也随之返回在检索结果中。   解决方法,使用BINARY属性进行检索,如:   以下为引用的内容:    Code: selectid,title,namefromachech_com.newswherebinarytitlelike'%a%'   返回的结果较之前正确,但英文字母区分大小写,故有时在检索如“Achech”及“achech”的结果是不一样的。知道了使用BINARY属性可以解决前面这个问题,再看看MySQL支持的UCASE及CONCAT函数,其中UCASE是将英文全部转成大写,而CONCAT函数的作用是对字符进行连接,以下是我们完全解决后的SQL语句:    Code: selectid,title,namefromachech_com.news   wherebinaryucase(title)likeconcat('%',ucase('a'),'%')   检索的步骤是先将属性指定为BINARY,以精确检索结果,而被like的title内容存在大小写字母的可能,故先使用ucase函数将字段内容全部转换成大写字母,然后再进行like操作,而like的操作使用模糊方法,使用concat的好处是传进来的可以是直接的关键字,不需要带“%”万用符,将“'a'”直接换成你的变量,在任何语言下都万事无忧了。当然你也可以这么写:    Code: selectid,title,namefromachech_com.newswherebinaryucase(title)likeucase('%a%')   检索的结果还算满意吧,不过速度可能会因此而慢N毫秒。
我要举报
如以上问答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
常州阔达装饰跟一米装饰哪家好啊?
有首歌,歌词最后是---点燃他心中仇恨的火焰-
谷涌社区居民委员会地址在哪,我要去那里办事
北美枫情地板优点有哪些?
饭店鱼缸怎么澳洲养龙虾
技嘉P61 S3 B3 主板 没有光驱排线接口
"生活就像一杯白开水"是哪首歌的歌词?帮一下
康颜美容馆地址在哪,我要去那里办事
我想开个日韩化妆品店,大家觉得怎么样?孕妇
我是鸡胸 我是应该把胸肌练大 还是练厚 才能
腰疼可以用热水袋暖吗?
黄花梨古典家具历史最高拍卖价价格是多少?
变压器的安装步骤是什么(实训报告要写)急!!!
谁知道网上哪个卖箫的商店`厂家最好?
保罗赛特家具的质量怎么样?
推荐资讯
上海到界首需要多久
吃圣元优博奶粉会早熟吗
韵达手持终端的物流管理系统超级管理员密码是
清远最有代表性的餐厅是哪一家啊?一定要好吃
安庆哪有英语四级的培训班?
睡觉怕吵,哪个牌子的隔音耳塞比较好
2012年长春林蛙油多少钱一斤
香港亮碧思集团十四楼和其他办公楼性质有什么
馨源甲醛清除剂是国内最好的吗?有没其他的?
博霏艺术培训地址在什么地方,想过去办事
电饭煲内胆厚度一般是多厚?
去韩国整下巴要多少钱
手机登qq时,显示手机磁盘不足,清理后重新登
刺客的套装怎么选啊?