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

MySQL中实现模糊查询有2种方式:一是用LIKE/NOT LIKE,二是用REGEXP/NOT REGEXP(或RLIKE/NOT RLIKE,它们是同义词)。

第一种是标准的SQL模式匹配。它有2种通配符:“_”和“%”。“_”匹配任意单个字符,而“%”匹配任意多个字符(包括0个)。举例如下:

SELECT * FROM table_name WHEREcolumn_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 WHEREcolumn_name LIKE ‘P%%’;
SELECT * FROM table_name WHERE column_name LIKE ‘P/%%’ ESCAPE‘/’; #第2个%被转义
SELECT * FROM table_name WHERE column_name LIKE ‘%_get%’ ESCAPE‘/’;

第二种是使用扩展正则表达式的模式匹配。先来看下扩展正则表达式一些字符的含义:
“.”:匹配任意单个字符
“?”:匹配前面的子表达式0次或1次。
“+”:匹配前面的子表达式1次或多次。
【MySQL】MySQL中的模糊查询和通配符转义 sql通配符转义
“*”:匹配前面的子表达式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 WHEREcolumn_name REGEXP ‘^50%{1,3}’;

正则匹配这东东还是挺有用处的,感兴趣的童鞋可以慢慢体会深入研究,O(∩_∩)O~

来源:http://www.letuknowit.com/archives/90

  

爱华网本文地址 » http://www.aihuau.com/a/25101016/313378.html

更多阅读

如何删除或者隐藏ps中的参考线和标尺? ps隐藏参考线

   有时候从网上下载psd文件打开时,用photoshop打开后,会看到横横竖竖的各色各样的长线,这其实就是photoshop中的“参考线和标尺”,那么如果我们不需要这些 辅助的功能呢?想删除或者 隐藏这些线,那该如何做呢?下面就是自己总结的几条经验,跟大家分享下。  

线程中的悲观锁和乐观锁 java中乐观锁和悲观锁

线程中的锁可以分为乐观锁和悲观锁,这两个都是实现锁机制的两种办法。悲观锁:根据字面意思,悲观,就是不是太好的。当一个线程访问这个数据的时候,悲观锁会把这个数据给锁住,不被其他线程所访问,直到这个线程完成了对数据的提交后,其他线程

fft谱分析中的栅栏效应和频谱泄露 fft频谱分析

http://blog.csdn.net/sunfoot001/archive/2010/09/22/5900917.aspxfft谱分析中的栅栏效应和频谱泄露栅栏效应:对采样信号的频谱,为提高计算效率,通常采用FFT算法进行计算,设数据点数为:  N = T/dt = T.fs  则计算得到的离散

显卡中的A卡和N卡 amd和intel的显卡区别

N卡与A卡的区别:AMD的显卡(A卡)设计思路本质上和Nvidia(N卡)是完全不同的,NVIDIA显卡(N卡)说简单点打造的是一个强悍的运算设备,而AMD 打造的是显卡。Nvidia的显卡,每个流处理器都搭配相应的缓存,并且设计上高度适应通用计算(通用计算简单

声明:《MySQL MySQL中的模糊查询和通配符转义 sql通配符转义》为网友寻欢人分享!如侵犯到您的合法权益请联系我们删除