学院首页 软件应用 编程开发 创意设计 认证培训 软件论坛
ASP ASP.NET PHP JSP SQL MYSQL Java VB

您的位置:学院 >> 编程开发 >> MYSQL >> MySQL中文模糊检索问题的解决方法


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


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

例子:

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

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

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

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

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

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

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

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

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

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

技术文章快速查找

栏目导航
软件应用
·操作系统 ·杀毒防黑 ·应用软件
·聊天软件 ·网络软件  
Web开发
·ASP ·JavaScript ·CGI
·JSP ·VbScript ·Web服务器
·PHP ·XML  
开发语言
·VB ·VC ·ASP.NET
·Java ·C/C++ ·Delphi
数据库开发
·MySQL ·SQL/Access ·PowerBuilder
·Oracle ·DB2  
网站设计
·Flash ·Dreamweaver ·HTML/CSS
·Fireworks ·FrontPage  
平面设计
·Photoshop ·CorelDraw ·AutoCAD
·FreeHand ·Illustrator ·3DsMAX
媒体动画
·Director ·Authorware ·Maya
·视频处理    


相关软件 产品库推荐
·笔记本 ·台式机 ·服务器
·数码相机 ·手机 ·GPS
·DV摄像机 ·MP3 ·MP4
·CPU ·硬盘 ·内存
·主板 ·显卡 ·显示器
·打印机 ·投影机 ·路由器

还没人留言,抢个先,哈哈!
对"MySQL中文模糊检索问题的解决方法"的评论 - 快速回贴
内容:
  [完成后可按Ctrl+Enter发布]

百度中 MySQL中文模糊检索问题的解决方法 相关内容
Google搜索中 MySQL中文模糊检索问题的解决方法 相关内容
雅虎中 MySQL中文模糊检索问题的解决方法 相关内容
Sogou搜索中 MySQL中文模糊检索问题的解决方法 相关内容

相关软件 最新回复帖子:

·Windows Vista 中卸载软件的不同方式
·没有mysql支持时的替代方案
·一个可以发送附件及HTML格式邮件的PHP类
·AutoCAD打造精致三维鸟笼实例详解
·Photoshop自定义水晶字特效样式
·AutoCAD三维基础实例教程
·PS为黑背景长发美女照片抠图换背
·用Photoshop自制个性摩托车贴花小经验
·轻松几步将美女照片处理为手工素描
·巧用Photoshop画笔轻松绘制创意特效


  相关软件 MySQL中文模糊检索问题的解决方法相关文章
MySQL的数据类型和建库策略详解 MySQL中修改密码及访问限制设置详解
MySQL用户Root密码为弱口令的攻击 MySQL数据库接口的VC具体实现与应用
设计高效合理的MySQL查询语句讲解 MySQL改善数据装载操作效率的策略
MYSQL,Oracle,SQL数据库在JSP中的驱动 MYSQL到ORACLE程序迁移的注意事项
如何用Tomcat和MySQL生成动态内容 在MySQL中执行SQL语句时的几个注意点
如何通过C API远程连接MySQL Server 致初学者:PHP比ASP优秀的七个理由
安装与卸载MySQL系统服务(常见问题) 怎样在VC、Delphi中使用MySQL ODBC驱动
如何实现两台MySQL数据库数据的同步 提高DB2 Web应用程序性能的五条规则
新手上路:MySQL初学者之使用指南 跟你谈谈MySQL数据库入门学习之入门篇
跟你谈谈MySQL数据库入门学习之安装篇 MySQL加密函数保护Web网站敏感数据