您的位置:知蚁博客 » 程序设计 » MySQL中的模糊查询和通配符转义

MySQL中的模糊查询和通配符转义

作者: 发布时间:2011-06-07 分类:程序设计 标签: 6,931人浏览

  MySQL中实现模糊查询有2种方式:一是用LIKE/NOT LIKE,二是用REGEXP/NOT REGEXP(或RLIKE/NOT RLIKE,它们是同义词)。
  第一种是标准的SQL模式匹配。它有2种通配符:“_”和“%”。“_”匹配任意单个字符,而“%”匹配任意多个字符(包括0个)。举例如下:

SELECT * FROM table_name WHERE column_name LIKE ‘m%’; #查询某字段中以m或M开头的所有记录
SELECT * FROM table_name WHERE column_name LIKE ‘%m%’; #查询某字段中包含m或M的所有记录
SELECT * FROM table_name WHERE column_name LIKE ‘%m’; #查询某字段中以m或M结尾的所有记录
SELECT * FROM table_name WHERE column_name LIKE ‘_m_’; #查询某字段中3个字符且m或M在中间的所有记录

  如果我们想查询包含通配符的字符串该怎么办呢?比如,50%或_get。答案就是:转义。可以用\来直接转义,或用ESCAPE定义转义字符来进行转义,都只是转义跟在后面的一个字符,例如:

SELECT * FROM table_name WHERE column_name LIKE ‘%50\%%’; /*第2个%被转义,查询某字段包含50%的所有记录*/
SELECT * FROM table_name WHERE column_name LIKE ‘%50/%%’ ESCAPE ‘/’; #第2个%被转义
SELECT * FROM table_name WHERE column_name LIKE ‘%\_get%’ ESCAPE ‘/’; /*“_”被转义,查询某字段包含_get的所有记录*/

  第二种是使用扩展正则表达式的模式匹配。先来看下扩展正则表达式一些字符的含义:
“.”:匹配任意单个字符
“?”:匹配前面的子表达式0次或1次。
“+”:匹配前面的子表达式1次或多次。
“*”:匹配前面的子表达式0次或多次。x*,表示0个或多个x字符;[0-9]*,匹配任何数量的数字。
“^”:表示匹配开始位置。
“$”:表示匹配结束位置。
“[]”:表示一个集合。[hi],表示匹配h或i;[a-d],表示匹配a、b、c、d中任一个。
“{}”:表示重复的次数。8{5},表示匹配5个8,即88888;[0-9]{5,11},表示匹配5到11个数字。
  再来看个例子:

SELECT * FROM table_name WHERE column_name REGEXP ‘^50%{1,3}’; /*查询某字段中以50%、50%%或50%%%开头的所有记录*/

  正则匹配这东东还是挺有用处的,感兴趣的童鞋可以慢慢体会深入研究,O(∩_∩)O~
原创文章请注明转载于知蚁博客,本文地址:http://www.letuknowit.com/archives/90

相关文章

11访客评论 ,博主回复2

  1. 我也正在学习中…

  2. 嘿嘿 沙发

  3. 这个技术性的 现在不想看了 呵呵

    混小子06-08 09:45 回复
  4. 技术文章,收藏

  5. 技术问题,学习了

  6. 博主的文章真是专业啊!

    天玉有双06-09 08:40 回复
  7. 有些高深,太专业了 呵呵

  8. 数据库知识十分匮乏,在老兄这里学习一下~

    一苇06-09 15:58 回复
  9. 我最烦 的就是数据库了。

    • 我最爱Access

      知蚁06-10 21:25 回复
  10. 好专业啊。。

    大鹏博客06-09 20:06 回复
  11. 第一次来,博主你的博文不错的,我会常来的

    • 多谢支持~~

      知蚁06-10 21:25 回复

我来说说

(必须)

(必须,保密)

你确定你已经看过文章了?
取消

无觅相关文章插件,快速提升流量