首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Oracle实现like多个值的查询

问题背景描述: 某天客户有一个需求,给定一批的手机号码或者电话号码,查询出相关的通话记录,以及相关的一些信息。...客户给定的被叫号码如图所示: 查询出来的结果如下图所示(本批次的结果不是上图导入的结果查询的,为了格式说明,因此导入两张结果不相关的图片): 由于客户给的被叫号码很不规范,查询的时候比较麻烦。...,settle_carrier,file_name from t_phonebill_201702 a where a.org_callee_num like '%13800100186%' 但是这样的号码有好多个...,有时候有一百多个,以上的sql只能查询一个号码的通话记录 一开始我想用游标实现,写一个游标,把被叫号码放入游标中,然后写一个循环,每次都依次查询一下, 但后来发现t_phonebill_201702数据量太大...,可以考虑使用简版,简版更易于了解,也能更清楚明白like多个值是如何实现的,但使用exists总是一个好习惯。

2.8K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Oracle查询优化-03操作多个表

    从多个表中返回丢失的数据 问题 解决方案 full join union all 13 多表查询时的空值处理 问题 解决方案 3.1 记录集的叠加 问题 要将来自多个表的数据组织到一起,就像将一个结果集叠加到另外一个上面一样...这些表不必有相同的关键字,但是他们对应列的数据类型必须相同。 解决方案 使用union all 把多个表中的行组合到一起。...union all select '-----', deptno from dept union all select dname, deptno from dept; 结论 UNION ALL将多个来源的行组合起来...该方式的左表和右表都返回所有的数据,但只有相匹配的数据显示在同一行,非匹配的行只显示一个表的数据。...问题 同时返回多个表中丢失的数据。

    3.1K20

    CA2002:不要锁定具有弱标识的对象

    值 规则 ID CA2002 类别 可靠性 修复是中断修复还是非中断修复 非中断 原因 线程尝试在具有弱标识的对象上获取锁。...规则说明 当可以跨应用程序域边界直接进行访问对象时,则认为该对象具有弱标识。 对于尝试获取对具有弱标识的对象的锁的线程,该线程可能会被其他应用程序域中持有对同一对象的锁的另一线程所阻止。...以下类型具有弱标识,并由规则标记: String 值类型的数组,包括整数类型、浮点类型和 Boolean。...,请使用“描述”部分中未包含的类型的对象。...何时禁止显示警告 如果锁定的对象为 this 或 Me,且 self 对象类型的可见性为专用或内部,并且不能使用任何公共引用访问该实例,可禁止显示该警告。 否则,请勿禁止显示此规则的警告。

    51350

    mybatis oracle 分页查询_oracle分页查询出现重复的问题

    大家好,又见面了,我是你们的朋友全栈君。 Oracle中分页查询因为存在伪列rownum,sql语句写起来较为复杂,现在介绍一种通过使用MyBatis中的RowBounds进行分页查询,非常方便。...使用MyBatis中的RowBounds进行分页查询时,不需要在 sql 语句中写 offset,limit,mybatis 会自动拼接 分页sql ,添加 offset,limit,实现自动分页。...public List> queryUserList(RowBounds rowbounds); //查询用户列表 } 对应的mapper.xml文件: /p> PUBLIC “-//mybatis.org...,即可实现分页查询数据。...总结 以上所述是小编给大家介绍的Oracle使用MyBatis中RowBounds实现分页查询功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。

    1.9K10

    SQL 找出分组中具有极值的行

    这些需求有两个共同点:一是需要做分组,有按部门分组、有按科目、也有按用户分组;二是在分组里面找到存在极值的行,是整行数据,而不只是极值。...就拿 emp 举例,要从 emp 表中获取每个部门薪资最高的员工的信息。emp 表的数据如下: ? 最终的查询结果如下图。 ? 要实现这个查询功能,有多少种实现方法呢?...窗口函数 如果你在用 MySQL 5.8+,窗口函数可能是你最先想到的办法,因为它足够简洁、简单。 先按部门分组,再对组内按照薪资降序排序,取排序序号为 1 的行即为部门最高薪资的员工的信息。...子查询 如果你的数据库还不支持窗口函数,那可以先对 emp 分组,取出每个部门中的最高薪资,再和原表做一次关联就能获取到正确的结果。...a 表匹配,a 表的数据都会查询出来。

    1.8K30

    Oracle里的查询转换

    Oracle里的查询转换,有称为查询改写,指oracle在执行目标sql时可能会做等价改写,目的是为了更高效的执行目标sql在10g及其以后的版本中,oracle会对某些类型的查询转换(比如子查询展开、...复杂视图合并等)计算成本,oracle会分别计算查询转换后的等价改写的sql的成本和原始sql的成本,如果改写后的sql的成本低于原始sql的成本,oracle才会对目标sql执行查询转换。...(inline view)然后再和外部查询的表、视图做连接(子查询展开) Oracle子查询前的where条件是以下 single-row(=,>,=,) exists not exists...2 对���不拆开的子查询会把它转换为一个内嵌视图的子查询展开。 对于第一种情况,Oracle 10g及以后的版本中,Oracle也不会考虑子查询展开的成本。...),   oracle将目标sql等级的改写成按分区union all的形式,不可用index union all可用index 11g r2引入 对同一个目标sql而言,oracle可能会采用不止一种的查询转换手段

    1.8K20

    oracle基础|oracle分组的用法|oracle分组查询|group by的使用

    目录 分组查询 概念 语法以及执行顺序 组函数 group by 子句 练习 having用法 练习 ---- 分组查询 概念 所谓组查询即将数据按照某列或者某些列相同的值进行分组,然后对该组的数据进行组函数运用...tips: 1.组函数可以出现的位置: select子句和having 子句 2.使用group by 将将行划分成若干小组。...max(),min():可以作用在任意类型的数据之上。对字符型数据的最大值,是按照首字母由A~Z的顺序排列,越往后,其值越大。...count([distinct] column | *) : count(*) : 统计表中所有的行数 count(column) : 返回所有非空行的行数 group by 子句 1.用来将表中的行划分成若干更小的组...目标查询: 平均工资 from : s_emp 条件 : 各部门 ,职称相同。

    5.8K20

    Oracle中的日期间查询

    在Oracle中,如果要进行日期间的查询需要用到Oracle的内置函数to_date()。...1、Oracle日期查询的边界问题 此外,日期间的查询还涉及一个边界问题,因为每个人的思维方式不同,因此写出的语句都不同。...但如果你忘记写了第2行的等于号了,那么如果一条记录的时间刚好是7月1日凌晨00:00分插入的,那么这条数据也就查不出来。 但实际上这条数据是7月1日的数据,应该被查询出来。...而在第3行中,如果你忘记在后边+1,那么程序就认为你查询的是比“2010-07-06 00:00:00”这个时间小的记录,那么7月6号当天的是数据就查不出来了。...-07-05 12:00:00', 'yyyy-mm-dd hh24:mi:ss'); 因为Oracle是不区分大小写的,所以如果你在第2行的to_date函数中把日期格式写成:'yyyy-MM-dd

    3.6K20

    oracle的行级触发器使用

    行级触发器: 当触发器被触发时,要使用被插入、更新或删除的记录中的列值,有时要使用操作前、后列的值....:NEW 修饰符访问操作完成后列的值 :OLD 修饰符访问操作完成前列的值 例1: 建立一个触发器, 当职工表 emp 表被删除一条记录时,把被删除记录写到职工表删除日志表中去。...TRIGGER tr_del_emp BEFORE DELETE -- 指定触发时机为删除操作前触发 ON scott.emp FOR EACH ROW -- 说明创建的是行级触发器...salary = 8000 WHERE employee_id = 177;  DELETE FROM employees WHERE employee_id in (177,170);  */ 例4: 利用行触发器实现级联更新...在修改了主表 regions 中的 region_id 之后( AFTER ),级联的、自动的更新子表 countries 表中原来在该地区的国家的 region_id 。

    1.6K50

    Oracle 中的树查询和 connect by

    Oracle 中的树查询和 connect by 使用 connect by 和 start with 来建立类似于树的报表并不难,只要遵循以下基本原则即可: 使用 connect by 时各子句的顺序应为...: select from where start with connect by order by prior 使报表的顺序为从根到叶(如果 prior 列是父辈)或从叶到根(如果 prior 列是后代...where 子句可以从树中排除个体,但不排除它们的子孙(或者祖先,如果 prior 列是后代)。...connect by 中的条件(尤其是不等于)消除个体和它所有的子孙(或祖先,依赖于怎样跟踪树)。 connect by 不能与 where 子句中的表连接在一起使用。 下面是几个例子 1....排除个体,但不排除它们的子孙 SELECT n_parendid, n_name, (LEVEL - 1), n_id FROM navigation WHERE n_parendid IS NOT NULL

    1.3K70

    oracle中如何优雅的递归查询

    一条sql怎么查出单表中含有父子关系的数据呢?...tab.name, '\' ) FROM tab WHERE LEVEL = 3 CONNECT BY PRIOR tab.id = tab.parid image.png 还有其他更优雅的写法吗...,需要注意的是如果with后面的值是子节点那么求出的就是他的父节点和祖宗节点,如果是父节点那么求出的就是他的子节点和子孙节点,如果不懂可以把上面start with 后面的条件改成 p.parent=0...关键词prior,prior跟它右边的父节点放在一起(prior p.parent)表示往父节点方向遍历, 反之,如果 prior跟子节点放在一起(prior p.id)表示往叶子方向遍历。...这里需要注意的 =p.id 放在prior关键词的前面或者后面都没什么关系,也就是上面可以这样写 p.id= prior p.paren。重要的是prior旁边放的

    10.8K62

    Oracle数据库的基本查询

    ,创建用户,用户去创建表 Oracle和MYSQL的差别 Oracle是多用户的, MYSQL是多数据库的 1....: 创建一个数据库,创建相应的表     Oracle: 创建一个表空间,创建用户,用户去创建表 Oracle和MYSQL的差别 Oracle是多用户的, MYSQL是多数据库的 1....Oracle安全级别要高,MYSQL开源免费 */ /* 基本查询:   SQL : 结构化查询语言   请听题: 请说一下SQL的分类以及每类常见的操作符都有哪些   四类:        ...: like         %  匹配多个字符 --查询员工姓名第三个字符是O的员工信息 select * from emp where ename like '__O%'; --查询员工姓名中,包含..., sal from emp order by deptno asc, sal desc; /*     函数: 必须要有返回值     单行函数: 对某一行中的某个值进行处理

    3.3K10

    oracle恢复删除的数据时长_oracle 闪回查询语句

    ORACLE恢复删除的数据 在网络搜集整理了关于恢复oracle已经删除或更新的数据方法,供参考; oracle提供了针对已经删除的数据恢复;分为两种方法:scn和时间戳两种方法恢复。...一、通过scn恢复删除且已提交的数据   1、获得当前数据库的scn号     select current_scn from v$database; (切换到sys用户或system用户查询)     ...查询到的scn号为:1499223   2、查询当前scn号之前的scn     select * from 表名 as of scn 1499220; (确定删除的数据是否存在,如果存在,则恢复数据;...如果不是,则继续缩小scn号)   3、恢复删除且已提交的数据     flashback table 表名 to scn 1499220; 二、通过时间恢复删除且已提交的数据   1、查询当前系统时间...可以尝试执行 alter table 表名 enable row movement; //允许更改时间戳 三、oracle数据update后怎么恢复到以前的数据 –查出你需要恢复的时间点 1、select

    85620
    领券