`
flyzonemu
  • 浏览: 35108 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

oracle sql语言模糊查询--通配符like的使用教程

 
阅读更多
oracle在Where子句中,可以对datetime、char、varchar字段类型的列用Like子句配合通配符选取那些“很像...”的数据记录,以下是可使用的通配符:
%   零或者多个字符
_    单一任何字符(下划线)
\     特殊字符



oracle10g以上支持正则表达式的函数主要有下面四个:
1,REGEXP_LIKE :与LIKE的功能相似
2,REGEXP_INSTR :与INSTR的功能相似
3,REGEXP_SUBSTR :与SUBSTR的功能相似
4,REGEXP_REPLACE :与REPLACE的功能相似
POSIX 正则表达式由标准的元字符(metacharacters)所构成:
'^' 匹配输入字符串的开始位置,在方括号表达式中使用,此时它表示不接受该字符集合。
'$' 匹配输入字符串的结尾位置。如果设置了 RegExp 对象的 Multiline 属性,则 $ 也匹
配 '\n' 或 '\r'。
'.' 匹配除换行符之外的任何单字符。
'?' 匹配前面的子表达式零次或一次。
'+' 匹配前面的子表达式一次或多次。
'*' 匹配前面的子表达式零次或多次。
'|' 指明两项之间的一个选择。例子'^([a-z]+|[0-9]+)$'表示所有小写字母或数字组合成的
字符串。
'( )' 标记一个子表达式的开始和结束位置。
'[]' 标记一个中括号表达式。
'{m,n}' 一个精确地出现次数范围,m=<出现次数<=n,'{m}'表示出现m次,'{m,}'表示至少
出现m次。
\num 匹配 num,其中 num 是一个正整数。对所获取的匹配的引用。
字符簇:
[[:alpha:]] 任何字母。
[[:digit:]] 任何数字。
[[:alnum:]] 任何字母和数字。
[[:space:]] 任何白字符。
[[:upper:]] 任何大写字母。
[[:lower:]] 任何小写字母。
[[:punct:]] 任何标点符号。
[[:xdigit:]] 任何16进制的数字,相当于[0-9a-fA-F]。
各种操作符的运算优先级
\转义符
(), (?:), (?=), [] 圆括号和方括号
*, +, ?, {n}, {n,}, {n,m} 限定符
^, $, anymetacharacter 位置和顺序
|
*/


其中关于条件,SQL提供了四种匹配模式:

1,%:表示任意0个或多个字符。可匹配任意类型和长度的字符,有些情况下若是中文,请使用两个百分号(%%)表示。

比如 SELECT * FROM [user] WHERE u_name LIKE '%三%'

将会把u_name为“张三”,“张猫三”、“三脚猫”,“唐三藏”等等有“三”的记录全找出来。

另外,如果需要找出u_name中既有“三”又有“猫”的记录,请使用and条件
SELECT * FROM [user] WHERE u_name LIKE '%三%' AND u_name LIKE '%猫%'

若使用 SELECT * FROM [user] WHERE u_name LIKE '%三%猫%'
虽然能搜索出“三脚猫”,但不能搜索出符合条件的“张猫三”。

2,_: 表示任意单个字符。匹配单个任意字符,它常用来限制表达式的字符长度语句:

比如 SELECT * FROM [user] WHERE u_name LIKE '_三_'
只找出“唐三藏”这样u_name为三个字且中间一个字是“三”的;

再比如 SELECT * FROM [user] WHERE u_name LIKE '三__';
只找出“三脚猫”这样name为三个字且第一个字是“三”的;


3. regexp_like 正则表达式函数查询
--查询FieldName中以1开头60结束的记录并且长度是7位
select * from fzq where FieldName like '1____60';
select * from fzq where regexp_like(FieldName,'1....60');
--查询FieldName中以1开头60结束的记录并且长度是7位并且全部是数字的记录。
--使用like就不是很好实现了。
select * from fzq where regexp_like(FieldName,'1[0-9]{4}60');
-- 也可以这样实现,使用字符集。
select * from fzq where regexp_like(FieldName,'1[[:digit:]]{4}60');
-- 查询FieldName中不是纯数字的记录
select * from fzq where not regexp_like(FieldName,'^[[:digit:]]+$');
-- 查询FieldName中不包含任何数字的记录。
select * from fzq where regexp_like(FieldName,'^[^[:digit:]]+$');
--查询以12或者1b开头的记录.不区分大小写。
select * from fzq where regexp_like(FieldName,'^1[2b]','i');
--查询以12或者1b开头的记录.区分大小写。
select * from fzq where regexp_like(FieldName,'^1[2B]');
-- 查询数据中包含空白的记录。
select * from fzq where regexp_like(FieldName,'[[:space:]]');
--查询所有包含小写字母或者数字的记录。
select * from fzq where regexp_like(FieldName,'^([a-z]+|[0-9]+)$');
--查询任何包含标点符号的记录。
select * from fzq where regexp_like(FieldName,'[[:punct:]]');

分享到:
评论

相关推荐

    oracle sql语言模糊查询--通配符like的使用教程详解

    Oracle SQL中的模糊查询是一种强大的数据检索工具,它允许用户使用通配符来查找不完全匹配特定模式的数据。通配符`LIKE`是这种查询的核心,它在`WHERE`子句中用于筛选满足特定模式的记录。本文将深入讲解`LIKE`...

    oracle sql语言模糊查询–通配符like的使用教程详解

    oracle在Where子句中,可以对datetime、char、varchar字段类型的列用Like子句配合通配符选取那些“很像…”的数据记录,以下是可使用的通配符: % 零或者多个字符 _ 单一任何字符(下划线) \ 特殊字符 oracle...

    SQL中查询中使用通配符

    SQL通配符主要用于`LIKE`、`GLOB`、`REGEXP`等操作符中,帮助我们进行更灵活的数据筛选。下面将详细介绍SQL中的几种常见通配符及其用法。 1. `%` - 百分号通配符 `%` 是SQL中最常用的通配符,它代表零个、一个或多...

    Oracle-SQL培训-V1.0

    根据提供的文档内容,我们可以归纳并深入探讨Oracle SQL的相关知识点,主要围绕SELECT语句及其使用方法展开。 ### Oracle-SQL培训-V1.0 #### 第一单元:SELECT语句 **SELECT语句的作用** - **列选择**:通过指定...

    简单模糊查询,是关于java和Oracle的一个模糊查询

    总的来说,Java和Oracle结合进行模糊查询涉及到了JDBC连接、SQL的`LIKE`操作符、PreparedStatement的使用以及JSP的前端交互。理解和熟练掌握这些技术,对于开发高效、安全的Web应用程序至关重要。

    SQL 通配符

    通过理解并熟练运用这些SQL通配符,你可以更有效地从数据库中检索信息,无论是在日常的数据查询还是在复杂的分析任务中。不过,请记住,尽管通配符非常强大,但过度依赖它们可能会导致性能问题,因此应适度使用,并...

    OracleSQL的优化.pdf

    优化器把使用 LIKE 操作符和一个没有通配符的表达式组成的检索表达式转换为一个"="操作符表达式。例如,优化器会把表达式 `ename LIKE 'SMITH'` 转换为 `ename = 'SMITH'`。优化器只能转换涉及到可变长数据类型的...

    Oracle通配符,运算符的使用

    在Oracle数据库中,通配符主要用于模糊查询,即通过模式匹配来检索符合特定条件的记录。主要通配符及其用途如下: ##### 1. **% (百分号)** - **定义**:表示零个、一个或多个字符。 - **示例**: - `SELECT * ...

    Oracle OCA 1Z0-051认证题库

    这些题目覆盖了SQL语言的基础用法,包括表的创建、视图的创建以及使用SQL查询中的通配符和转义字符等知识点。通过这些练习题的学习,可以帮助考生更好地掌握Oracle数据库中的SQL语言基础,并为参加Oracle OCA 1Z0-...

    oracle SQL优化实例

    ### Oracle SQL优化实例详解 #### 一、减少I/O操作 在Oracle数据库中,I/O操作通常是查询执行...通过以上实例可以看出,合理使用索引、优化查询结构、调整查询顺序等方法可以在很大程度上提高Oracle SQL查询的性能。

    Oracle中常用的通配符

    在Oracle SQL中,通配符主要用于`LIKE`操作符中,用于模糊查询。常见的通配符包括`%`、`_`等。此外,还有一些特殊的字符,如`#`、`[`、`]`等,它们虽然不是严格意义上的通配符,但在特定场景下可以起到类似的作用。 ...

    最全的ORACLE-SQL笔记

    `在模糊匹配中使用转义字符避免与通配符冲突。 22. **排序数据**:`select * from dept order by deptno desc;`使用ORDER BY对结果集进行升序或降序排序。 这些是Oracle SQL基础操作的一部分,实际应用中还有更...

    精通SQL--结构化查询语言详解

    6.5 使用like进行模糊查询 109 6.5.1 like运算符 109 6.5.2 “%”通配符 110 6.5.3 “_”通配符 112 6.5.4 “[]”通配符 114 6.5.5 使用escape定义转义符 115 第7章 连接符、数值运算与函数 117 7.1 本章实例...

    oracle_sql测试题-2[文].pdf

    【知识点详解】 ...这些是Oracle SQL测试题中涉及的一些基础和进阶知识点,涵盖了数据选取、过滤、聚合、排序、连接、子查询等多个方面。理解和熟练掌握这些知识点对于进行有效的数据库查询和数据分析至关重要。

    Oracle-SQL优化.docx

    带通配符(%)的 like 语句可以提高查询效率,但需要注意避免使用不必要的通配符。 1.4 Order by 语句 在编写 SQL 语句时,需要注意 Order by 语句的使用。Order by 语句可以提高查询效率,但需要注意避免使用不必...

    ORACLE SQL 语句(典型应用总结).pdf

    - **关键字与标识符**:Oracle SQL中的关键字应全部使用大写字母书写,而表名、字段名等标识符则应使用小写字母或与数据库约定的格式一致。 #### 2. DISTINCT `DISTINCT`关键字用于去除查询结果中的重复记录,例如...

    PL_SQL_Oracle基础教程

    - `[NOT] LIKE`:模糊匹配,通常与通配符一起使用。 - `IS [NOT] NULL`:判断某列是否为空。 - **统配符**: - `%`:匹配任何数量的字符。 - `_`:匹配一个字符。 - **逻辑运算符**: - `AND`:两个条件都必须...

    Oracle SQL性能优化技巧总结

    在Oracle数据库中,SQL语句的执行顺序对查询性能有着显著的影响。对于基于规则的优化器而言,FROM子句中表的顺序至关重要。Oracle的解析器会按照从右至左的顺序处理FROM子句中的表名,因此,位于FROM子句最右侧的表...

Global site tag (gtag.js) - Google Analytics