在这个信息量剧增的时代,怎样帮助用户从海量数据中检索到想要的数据。模糊查询是不可缺少的。

那么在Oracle中模糊查询是怎样实现的呢?

 

一、我们能够在where子句中使用likekeyword来达到Oracle模糊查询的效果;在Where子句中。能够对datetime、char、varchar字段类型的列用Likekeyword配合通配符来实现模糊查询,下面是可使用的通配符:

(1)% :零或者多个字符,使用%有三种情况

字段 like '%keyword%'字段包括"keyword"的记录 字段 like 'keyword%'字段以"keyword"開始的记录字段 like '%keyword'字段以"keyword"结束的记录

样例:

SELECT * FROM [user] WHERE uname     LIKE '%三%'

搜索结果:“张三”。“小三”、“三脚猫”,“猫三脚”  有“三” 的记录全找出来。

SELECT * FROM [user]     WHERE uname LIKE '%三'  (从后開始匹配)

搜索结果:“张三”,“小三”

另外,假设须要找出uname中既有“三”又有“猫”的记录。请使用and条件

SELECT *FROM [user] WHERE uname LIKE '%三%' AND uname LIKE '%猫%'

若使用SELECT * FROM [user] WHERE     uname LIKE '%三%猫%',尽管能搜索出“三脚猫”,但不能搜索出“猫三脚”。

 

(2)_: 单一不论什么字符(下划线)经常使用来限制表达式的字符长度语句:

样例:

SELECT * FROM [user] WHERE uname     LIKE '_三_'

搜索结果:“猫三脚”这样uname为三个字符且中间一个是“三”的;

SELECT * FROM [user] WHERE uname     LIKE '三__';

搜索结果:“三脚猫”这样uname为三个字符且第一个是“三”的;

 

(3)[]:在某一范围内的字符,表示括号内所列字符中的一个(相似正則表達式)。指定一个字符、字符串或范围。要求所匹配对象为它们中的任一个。

样例:

 SELECT * FROM [user] WHERE u_name LIKE     '[张李王]三'

搜索结果:“张三”、“李三”、“王三”(而不是“张李王三”);

如 [ ]内有一系列字符(01234、abcde之类的)则可略写为“0-4”、“a-e”

SELECT * FROM [user] WHERE u_name     LIKE '老[1-9]'

搜索结果:“老1”、“老2”、……、“老9”。

 

(4)[^]: 不在某范围内的字符。使用方法与[ ]相反。

 

二、在Oracle中提供了instr(strSource,strTarget)函数,比使用'%keyword%'的模式效率高非常多。

 

instr函数也有三种情况:

instr(字段,'keyword')>0相当于 字段like '%keyword%'

instr(字段,'keyword')=1相当于 字段like 'keyword%'

instr(字段,'keyword')=0相当于 字段not like
'%keyword%'

样例:

SELECT * FROM [user]     WHEREinstr(uname
,'三')>0

       
使用方法參照上面的Like 就可以

 

特殊使用方法:

select id, namefrom user where instr('101914, 104703', id) > 0;

它等价于

select id, namefrom user where id = 101914 or id = 104703;

 

 

在数据量比較少的时候,能够直接使用上面这两种方法。可是当数据量特别大的时候。我们就应该考虑效率的问题了。

虽说在效率上Instr比likekeyword方法效率要高出不少,但这也不过在一定程度上而言。远不能满足我们的须要。

 

 为什么keyword查询效率这么低呢?这是因为在利用这些keyword查询的时候,数据库系统不是通过索引来查询。而是採用顺序扫描的方式来查询。显然,真是这样的技术特性,造成了Likekeyword查询效率的低下。特别是在复杂查询或者大表查询中。用户能够明显感觉到速度比較慢。

 

 怎么解决效率的难题呢?答案也正是索引。

合理的利用索引,能够大幅度的提升数据库的查询性能。

关于索引的合理应用,还在研究中。

Oracle 模糊查询方法的更多相关文章

  1. JAVA 模糊查询方法

    当我们需要开发一个方法用来查询数据库的时候,往往会遇到这样一个问题:就是不知道用户到底会输入什么条件,那么怎么样处理sql语句才能让我们开发的方法不管接受到什么样的条件都可以正常工作呢?这时where ...

  2. Oracle 模糊查询 优化

    模糊查询是数据库查询中经常用到的,一般常用的格式如下: (1)字段  like '%关键字%'   字段包含"关键字"的记录   即使在目标字段建立索引也不会走索引,速度最慢 (2 ...

  3. 某表含有N个字段超精简模糊查询方法

    我们在做多个字段模糊查询时,是不是觉得非常麻烦?比如我要模糊查询某表多个字段存在某数据时,如下 select * from table where a like '%key%' or b  like ...

  4. Oracle模糊查询CONCAT参数个数无效

    在使用MyBatis操作Oracle数据库的时候,写模糊查询突然发现原本在MySql中正确的代码,在Oracle中报错,参数个数无效 <if test="empId!=null and ...

  5. vue 如何实现 Input 输入框模糊查询方法

    原理:原生js的indexOf() 方法,该方法将从头到尾地检索数组,看它是否含有对应的元素.开始检索的位置在数组 start 处或数组的开头(没有指定 start 参数时).如果找到一个 item, ...

  6. oracle模糊查询mysql的区别

    https://blog.csdn.net/weixin_38673554/article/details/86503982#_1 oracle与使用mysql的区别 https://www.cnbl ...

  7. 关于mongodb按照字段模糊查询方法

    模糊查询:tname包含某个关键字测试' cd /opt/soft/mongodb/bin ./mongo --host 192.168.0.1  --port 17017  test db.test ...

  8. oracle模糊查询提高效率的方法

    转载:https://blog.csdn.net/weixiaohuai/article/details/83513957 https://blog.csdn.net/chihen/article/d ...

  9. oracle模糊查询效率提高

    1.使用两边加‘%’号的查询,oracle是不通过索引的,所以查询效率很低. 例如:select count(*) from lui_user_base t where t.user_name lik ...

随机推荐

  1. C指针计算字符串长度

    #include <stdio.h> int stringLength (const char *string) { const char *cptr = string; while ( ...

  2. 项目中遇到的超卖问题及解决办法(使用go做测试工具)

    超卖问题:在一个很短的时间内,Mysql的数据状态在 取出,比较,提交,或修改中,另外一个进程访问数据导致的超卖问题. 案例: 1.前端没有做限制,如果用户连续点击签到,那么会有多条数据发送到后端,如 ...

  3. Django框架基础知识08-表关联对象及多表查询

    1.自定义主键字段的创建 AutoFiled(pirmary_key=True) # 一般不会自定义,int类型,自增长 一般不自定义主键. 2.order_by asc desc from djan ...

  4. LeetCode(171) Excel Sheet Column Number

    题目 Related to question Excel Sheet Column Title Given a column title as appear in an Excel sheet, re ...

  5. springMVC 文件上传 HTTP Status 400 – Bad Request

    可能原因是:multipartResolver没有配置正确 请看解决方案: <!--文件上传 id必须为multipartResolver,不然报错HTTP Status 400 – Bad R ...

  6. 常见Bean映射工具分析评测及Orika介绍

    原地址:http://tech.dianwoda.com/2017/11/04/gao-xing-neng-te-xing-feng-fu-de-beanying-she-gong-ju-orika/ ...

  7. web移动端小tip,box-flex

    1,移动端页面 最重要的标签: <meta content="width=device-width,initial-scale=1.0,minimum-scale=1,maximum- ...

  8. spring boot 没有主清单属性

  9. 动态规划:HDU 1114 Piggy-Bank

    Problem Description Before ACM can do anything, a budget must be prepared and the necessary financia ...

  10. 洛谷——P1265 公路修建

    P1265 公路修建 题目描述 某国有n个城市,它们互相之间没有公路相通,因此交通十分不便.为解决这一“行路难”的问题,政府决定修建公路.修建公路的任务由各城市共同完成. 修建工程分若干轮完成.在每一 ...