MySQL正则表达式初步
如果想要了解完整的MySQL手册, 请访问: MySQL 5.1参考手册
你还可以学习: MySQL学习精粹
我们知道,在SQL之中,可以用 like 这个谓词(表达式) 来进行模糊检索,并支持 %,?,_等占位符.
但是,这个模糊检索的功能有很多限制,简单来说就是太模糊了。
在MySQL中提供了 REGEXP 关键字来支持正则表达式,当然,只是一些很简单的正则啦。
首先,我们构造一些测试数据。
-- 建表 USE test; DROP TABLE IF EXISTS t_regcustomer; CREATE TABLE t_regcustomer ( id INT(10) AUTO_INCREMENT ,name VARCHAR(256) ,age INT(10) , PRIMARY KEY(id) ) COLLATE='utf8_general_ci' ENGINE=InnoDB;
增加一些测试数据:
-- 插入一些测试数据: TRUNCATE TABLE t_regcustomer; INSERT INTO t_regcustomer(name, age) VALUES ('王明',20); INSERT INTO t_regcustomer(name, age) VALUES ('王大',21); INSERT INTO t_regcustomer(name, age) VALUES ('小王',22); INSERT INTO t_regcustomer(name, age) VALUES ('小王2',22); INSERT INTO t_regcustomer(name, age) VALUES ('敲不死',23); INSERT INTO t_regcustomer(name, age) VALUES ('憨憨',24); INSERT INTO t_regcustomer(name, age) VALUES ('憨憨2',24); INSERT INTO t_regcustomer(name, age) VALUES ('郭靖名',25); INSERT INTO t_regcustomer(name, age) VALUES ('郭靖2',25); INSERT INTO t_regcustomer(name, age) VALUES ('郭靖3',25); INSERT INTO t_regcustomer(name, age) VALUES ('郭得缸',25) ,('大鹏',20) ,('大鹏2',20) ,('大鹏3',20) ,('二鹏',19) ,('鹏鹏',18) ,('鹏鹏1',18) ,('小鹏',17) ,('AAA',17) ,('aaa',17) ,('SS',17) ,('s2',17) ,('ss',17) ;
1. 最简单的查询:
SELECT * FROM t_regcustomer;
2. 指定列名查询
SELECT c.id, c.name, c.age FROM t_regcustomer c ;
3. 对查询结果排序
SELECT c.id, c.name, c.age FROM t_regcustomer c ORDER BY c.age ASC ;
4. like 模糊检索
%匹配任意数量(0~n)的任意字符
SELECT c.id, c.name, c.age FROM t_regcustomer c WHERE c.name LIKE '%鹏%' ORDER BY c.age ASC ;
5. regexp 关键字
.匹配任意一个字符
注意此处因为没有起始(^)和结束($)限定符,所以只要列中出现的行都会被检索出来.
SELECT c.id, c.name, c.age FROM t_regcustomer c WHERE c.name REGEXP '.鹏.' ORDER BY c.age ASC ;
6. 正则起始限定符
SELECT c.id, c.name, c.age FROM t_regcustomer c WHERE c.name REGEXP '^王' ORDER BY c.age ASC ;
7. 大小写敏感
SELECT c.id, c.name, c.age FROM t_regcustomer c WHERE c.name REGEXP BINARY '^s' ORDER BY c.age ASC ;
8. 正则或运算
SELECT c.id, c.name, c.age FROM t_regcustomer c WHERE c.name REGEXP BINARY 'a|s' ORDER BY c.name ASC ;
9. 组运算正则
[123] 表示 1、2、3这3个数字之一出现即可
SELECT c.id, c.name, c.age FROM t_regcustomer c WHERE c.name REGEXP BINARY '鹏[123]' ORDER BY c.name ASC ;
[1-9] 匹配 1、2、3、.... 8、9
SELECT c.id, c.name, c.age FROM t_regcustomer c WHERE c.name REGEXP BINARY '鹏[1-9]' ORDER BY c.name ASC ;
10. 转义
使用 \\
可以转义 \.[]()?-| 以及分页,换行符号等
11.更多内容
请查阅 《MySQL必知必会》 68页 正则表达式
MySQL正则表达式初步的更多相关文章
- MySql 正则表达式简介及使用
MySql正则表达式简介及使用 by:授客 QQ:1033553122 简介 正则表达式描述了一组字符串,该字符放置于REGEXP工具后面.作用是将一个正则表达式与一个文本串进行比较. 最简单的正则表 ...
- 二十二、MySQL 正则表达式
MySQL 正则表达式 在前面的章节我们已经了解到MySQL可以通过 LIKE ...% 来进行模糊匹配. MySQL 同样也支持其他正则表达式的匹配, MySQL中使用 REGEXP 操作符来进行正 ...
- mysql正则表达式及应用
mysql where子句的模式匹配 今天在应用中遇到了这样的一个问题,有一个字段 t1,其中的值类似于:1,1,1,2,3,3,4,4,5,5,2,4,3,2,1,2 需要从里面搜索出比如说:第一个 ...
- DB-MySQL:MySQL 正则表达式
ylbtech-DB-MySQL:MySQL 正则表达式 1.返回顶部 1. MySQL 正则表达式 在前面的章节我们已经了解到MySQL可以通过 LIKE ...% 来进行模糊匹配. MySQL 同 ...
- 【数据库开发】在Windows上利用C++开发MySQL的初步
[数据库开发]在Windows上利用C++开发MySQL的初步 标签(空格分隔): [编程开发] Windows上在上面配置环境的基础上开展一个小demo链接数据库,没想到中间也出现了这么多的问题,简 ...
- MySQL正则表达式
正则表达式作用是匹配方本,将一个模式(正则表达式)与一个文本串进行比较. MySQL用WHERE子句对正则表达式提供了初步的支持,允许你指定用正则表达式过滤SELECT检索出的数据. MySQL仅支持 ...
- 使用MySQL正则表达式查询
MySQL用WHERE子句对正则表达式提供了初步的支持,允许你指定用正则表达式过滤SELECT检索出的数据. REGEXP后所跟的东西作为正则表达式处理. 代码 SELECT prod_name FR ...
- 使用MySQL正则表达式 __MySQL必知必会
正则表达式作用是匹配方本,将一个模式(正则表达式)与一个文本串进行比较. MySQL用WHERE子句对正则表达式提供了初步的支持,允许你指定用正则表达式过滤SELECT检索出的数据. MySQL仅支持 ...
- MySQL 正则表达式
介绍 正则表达式用来描述或者匹配符合规则的字符串.它的用法和like比较相似,但是它又比like更强大,能够实现一些很特殊的规则匹配:正则表达式需要使用REGEXP命令,匹配上返回"1&qu ...
随机推荐
- Zookeeper 客户端API调用示例(基本使用,增删改查znode数据,监听znode,其它案例,其它网络参考资料)
9.1 基本使用 org.apache.zookeeper.Zookeeper是客户端入口主类,负责建立与server的会话 它提供以下几类主要方法 : 功能 描述 create 在本地目录树中创建 ...
- linux TCP头部的构造的简单分析
TCP的头部的构造是在函数tcp_transmit_skb()中进行的 函数片段如下: /* Build TCP header and checksum it. */ th = tcp_hdr(skb ...
- Xcode中lldb的REPL调试方法
Xcode中lldb调试器有一个repl语句,可以用来模拟swift解释器的REPL行为,即Read Eval Print Loop. 在Xcode里随意打开程序,中断入调试器.在调试控制台中输入re ...
- 剑指Offer——Java实现栈和队列的互模拟操作
剑指Offer--Java实现栈和队列的互模拟操作 栈模拟队列 题目:JAVA实现用两个栈来实现一个队列,完成队列的Push和Pop操作.队列中的元素为int类型. 思路:其实就是把队列正常入 ...
- Redis源码剖析--源码结构解析
请持续关注我的个人博客:https://zcheng.ren 找工作那会儿,看了黄建宏老师的<Redis设计与实现>,对redis的部分实现有了一个简明的认识.在面试过程中,redis确实 ...
- JAVA面向对象-----成员内部类的访问方式
成员内部类的访问方式 1.内部类可以直接访问外部类的成员属性.(孙悟空相当于内部类飞到牛魔王的肚子里面去). 2.外部类需要访问内部类的成员属性时需要创建内部类的对象. 1.在外部类的成员函数中创建内 ...
- 使用Dialog实现全局Loading加载框
Dialog实现全局Loading加载框 很多人在实现Loading加载框的时候,都是在当前的页面隐藏一个Loading布局,需要加载的时候,显示出来,加载完再隐藏 使用Dialog实现Loading ...
- android 集成微博常见问题
我们在做微博集成登录.分享.聊天的时候,肯定会遇到很多的坑,这里总结下常见的问题. 文件不存在 C8998 的解决方法 如图我们走微博授权登录的时候如果OAuth2.0 授权设置回调页面设置和本地的不 ...
- JBOSS EAP 6 系列四 EJB实现——调用(贯穿始终的模块)
本文主要介绍在JBOSS EAP 6.2(或者JBOSS AS7)中模块是如何贯穿EJB实现的始终.延续上一博文<认识模块的使用>的话题继续聊JBOSS做为模块申明式容器的这一特性在EJB ...
- iOS开发之Xcode8推出的WKWebView与UIWebView的使用
一.整体介绍 UIWebView自iOS2就有,WKWebView从iOS8才有,毫无疑问WKWebView将逐步取代笨重的UIWebView.通过简单的测试即可发现UIWebView占用过多内存,且 ...