[每日一题] OCP1z0-047 :2013-08-22 正则表达式---[^Ale|ax.r$]'
正确答案:DE
一、Oracle正则表达式的相关知识点
'[^Ale|ax.r$]':
^:匹配行的开始字符
$:匹配行的结束字符
[]:方括号表示指定一个匹配列表,该列表匹配列表中显示的任何表达式。
[^]:同上面相反,非匹配列表表达工。
.:匹配任意一个字符(除了NULL)
|:替换元字符;结束第一个选项并开始下一个替换表达式
[^Ale|ax.r$]'中^表示只匹配不在集合{'A','l','e','|','a','x','.','r','$'}中的字符, 此处的'|'、'.'、'$'只是表示普通的字符,而非匹配符。字符串: [Ale|ax.r$] 匹配Alex,Alax ,Alxer ,A,l,e,a.............
不包含 A l e a x r的串,等效于[^Aleaxr],只要在串里面找到符合条件的字符(哪怕就一个)就算匹配。
先来看一下答案:
gyj@MYDB> with gyj_test as (
2 select 'Alex' name from dual
3 union all
4 select 'Alax' name from dual
5 union all
6 select 'Alxer' name from dual
7 union all
8 select 'Alexender' name from dual
9 union all
10 select 'Alexendar' name from dual)
11 select * from gyj_test where regexp_like(name,'[^Ale|ax.r$]'); NAME
---------
Alexender
Alexendar
二、分析:
'^Ale|ax.r$'――表示匹配Ale或ax开头的字符串,.表示任一字符。
gyj@MYDB> create table gyj_test1 (id int,name varchar2(20)); Table created. gyj@MYDB> insert into gyj_test1 values(1,'Alex'); 1 row created. gyj@MYDB> insert into gyj_test1 values(2,'Alax'); 1 row created. gyj@MYDB> insert into gyj_test1 values(3,'Alxer'); 1 row created. gyj@MYDB> insert into gyj_test1 values(4,'Alexender'); 1 row created. gyj@MYDB> insert into gyj_test1 values(4,'Alexendar'); 1 row created. gyj@MYDB> commit; Commit complete.
gyj@MYDB> select * from gyj_test1 where regexp_like(name,'^Ale|ax.r$'); ID NAME
---------- --------------------
1 Alex
4 Alexender
4 Alexendar
三、以上的SQL语句等价于:
gyj@MYDB> select * from gyj_test1 where regexp_like(name,'^Ale')
2 union all
3 select * from gyj_test1 where regexp_like(name,'ax.r$'); ID NAME
---------- --------------------
1 Alex
4 Alexender
4 Alexendar
四、^出现在[]中表示否定,查询的结果集里含有不是中括号里的字母Aleaxr
gyj@MYDB> select * from gyj_test1 where regexp_like(name,'[^Ale|ax.r$]'); ID NAME
---------- --------------------
4 Alexender
4 Alexendar
[每日一题] OCP1z0-047 :2013-08-22 正则表达式---[^Ale|ax.r$]'的更多相关文章
- CISP/CISA 每日一题 22
CISSP 每日一题(答)What should be done to verify patcheshave been applied? Auditpatches, or use a vulnerab ...
- 老男孩IT教育-每日一题汇总
老男孩IT教育-每日一题汇总 第几天 第几周 日期 快速访问链接 第123天 第二十五周 2017年8月25日 出现Swap file….already exists以下错误如何解决? 第122天 2 ...
- PL/SQL Challenge 每日一题:2014-3-14 11gR2中带RELIES_ON子句的RESULT_CACHE函数
PL/SQL Challenge 每日一题:2014-3-14 11gR2中带RELIES_ON子句的RESULT_CACHE函数 最先答对且答案未经编辑的puber将获得纪念章一枚(答案不可编辑但可 ...
- 【剑指Offer】简单部分每日五题 - Day 1
今天开始更新leetcode上<剑指Offer>的题解,先从简单难度开始.预计按下列顺序更新: 简单难度:每日5题 中等难度:每日3题 困难难度:每日1题 17 - 打印从1到最大的n位数 ...
- 【JavaScript】【dp】Leetcode每日一题-解码方法
[JavaScript]Leetcode每日一题-解码方法 [题目描述] 一条包含字母 A-Z 的消息通过以下映射进行了 编码 : 'A' -> 1 'B' -> 2 ... 'Z' -& ...
- 【python】Leetcode每日一题-逆波兰表达式求值
[python]Leetcode每日一题-逆波兰表达式求值 [题目描述] 根据 逆波兰表示法,求表达式的值. 有效的算符包括 +.-.*./ .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 说 ...
- 【Java每日一题】20170106
20170105问题解析请点击今日问题下方的"[Java每日一题]20170106"查看(问题解析在公众号首发,公众号ID:weknow619) package Jan2017; ...
- 【Java每日一题】20170105
20170104问题解析请点击今日问题下方的"[Java每日一题]20170105"查看(问题解析在公众号首发,公众号ID:weknow619) package Jan2017; ...
- 【Java每日一题】20170104
20170103问题解析请点击今日问题下方的"[Java每日一题]20170104"查看(问题解析在公众号首发,公众号ID:weknow619) package Jan2017; ...
随机推荐
- OpenGL绘制环形渐变
开始看计算机图形学和OpenGL,挺有意思就自己随便写了一些效果. 以中间点坐标为圆心,计算每一点和圆心距离,根据距离算出一个RGB值,于是整体便呈现环形分布. 代码如下: #include < ...
- UDP聊天实现(简单版)
两者代码基本一致 关于套接字: 甲方: #include <stdio.h> #include <string.h> #include <netinet/in.h> ...
- svn 同步到web目录
windows hook 下 @echo offSET REPOS=%1SET REV=%2SET DIR=%REPOS%/hooksSET PATH=%PATH%;SET WORKING=D:/w ...
- wifi相关协议
IEEE 802.11Wi-Fi 协议摘要 协议 频率 信号 最大,数据率 传统802.11 2.4GHz FHSS或DSSS 2Mbps 802.11a 5GHz OFDM 54Mbps 802.1 ...
- Java学习疑惑(8)----可视化编程, 对Java中事件驱动模型的理解
我们编写程序就是为了方便用户使用, 我觉得UI设计的核心就是简洁, 操作过于繁琐的程序让很大一部分用户敬而远之. 即使功能强大, 但是人们更愿意使用易于操作的软件. 近年流行起来的操作手势和逐渐趋于成 ...
- Unix/Linux环境C编程入门教程(9) unbntu CCPP开发环境搭建
1. 首先启动VMware,如果没有安装,请查看前面VMware的安装视频 2 启动虚拟机向导,选择自定义 3 单击下一步 4 选择稍后安装操作系统 5 .选择unbntu 64linux ...
- ajax、form提交乱码
ajax 传参乱码:encodeURI(encodeURI(username)) form 传参乱码:request.setCharacterEncoding("UTF-8"); ...
- Ubuntu下获取Nexus7的Root权限
一.准备 下载获取Root权限的工具包. 下载地址: http://downloadandroidrom.com/file/Nexus7/rooting/Nexus7Root.zip 二.解锁 Ubu ...
- poj1552---枚举
#include <stdio.h> #include <stdlib.h> int main() { ],th=,i,j; while(scanf("%d" ...
- POJ 3111 K Best(最大化平均值)
题目链接:click here~~ [题目大意]有n个物品的重量和价值各自是Wi和Vi.从中选出K个物品使得单位重量的价值最大,输出物品的编号 [解题思路]:最大化平均值的经典.參见click her ...