首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Oracle查询实例

Oracle查询实例 今天工作中遇到了一个关于查询,琢磨了半天,终于想明白了,这里简单记录一下。...distinct函数 说到,可能第一反应就是distinct函数,但其实distinct只是针对单一字段的有效。...n.phonenumber) as CNT_Invalid from IVR_NO_EXIST n group by n.dial_date order by n.dial_date 结果还是可以正常显示的,但是每一的空号数量之和要大于总的非重复空号数...多个条件时的 其实这里出现问题的不在于同一里有重复的空号,每一的空号其实还是unique的,只是可能后面出现的空号是前些已经识别出来的,这部分其实不应该被计入到非重复的空号中,因为前面已经记过一次了...dial_date phone_number 20200731 12345678910 20200806 12345678910 可以看出其实同一个号码在不同的记录都被计入了,这是不行的,我们必须要对这部分进行

92230

mysql分组查询

group by (1) group by的含义:将查询结果按照1个或多个字段进行分组,字段值相同的为一组 (2) group by可用于单个字段分组,也可用于多个字段分组 select * from...1001 | 张三 | 26 | 男 | beijinghdq | +------+------+--------+------+------+------------+ 根据sex字段来分组...只显示出每组的第一条记录 所以group by单独使用时的实际意义不大 group by + group_concat() (1) group_concat(字段名)可以作为一个输出字段来使用, (2) 表示分组之后...,根据分组结果,使用group_concat()来放置每一组的某字段的值的集合 select sex from employee group by sex; +------+ | sex | +---...女 | 1 | | 男 | 3 | +------+------------+ group by + having (1) having 条件表达式:用来分组查询后指定一些条件来输出查询结果

3.8K90

mysql连接查询分组查询

连表查询在项目中用的很频繁,今天在这里总结一下 假设两张表 user: id name dept_id dept: id dept_name 交叉连接(cross join) 交叉连接是一个笛卡尔积的结果...t1 union select * from t2 t1id t1str 1 1 2 2 3 3 2 a 3 b t1和t2的结果集被显示在了一起,默认以t1的字段为准,这里要注意: 使用union查询的时候...,两个语句查询出的字段数目必须要相同 查询的结果中两个语句重复的数据会被合成一条,如果要显示重复的记录,就需要使用 union all 全连接(full join) 我查了一下资料,mysql并不支持全连接...from t1 left join t2 on t1.t1id = t2.t2id t1id t1str t2id t2str 1 1 null null 2 2 2 a 3 3 3 b 参考资料 mysql...多表查询 mysql联表查询总结

3.3K20

oracle数据库查询_oracle查询重数据

oracle数据库中有如下一张表,包含id,loginid,name,researchtime等字段,其中name字段中的数据有重复,查询数据时要重复数据只取一条,利用row_number ()over...,row_number() over(partition by a.name order by researchtime desc) sui from HY_RECORDS a 先按照name列进行分组...,在根据researchtime列进行降序排列,最后对每一条记录返回一个序列号sui,如下图 把上图查询出来的数据作为一个整体再次进行条件查询操作 select id,name,loginid,...如下图 在此基础上还可以进行其他条件查询,例如查询loginid=2572的数据,并将数据按时间进行降序排列 select id,name,loginid,researchtime from(...) where su=1 and loginid =2572 order by researchtime desc) where rownum < 7 结果如下图 好了,oracle数据库查询一些简单的查询语句到此结束

1.8K30

MySQL(八)子查询分组查询

(实际上,MySQL执行了2个select操作),where子句中使用子查询,必须保证select语句具有与where子句中相同数目的列;   子查询一般与in操作符结合使用,但也可用于测试等于(=)、...PS:使用子查询建立查询的最可靠方法是逐渐进行(首先建立最内层的查询,确认后用硬编码数据建立外层查询,由内到外) 二、组合查询 MySQL允许执行多个查询(多条select语句),并将结果作为单个查询结果集返回...以下两种基本情况,需要使用组合查询: ①在单个查询中从不同表返回类似结构的数据; ②对单个表执行多个查询单个查询返回数据; 1、union union可将多条select语句的结果组合成单个结果集,...select user_id, mobile_id, mobile_num from mobuletables where user_id in (10000,10010); 这条SQL语句中,union指示MySQL...mobile_id, mobile_num from mobuletables where user_id in (10000,10010) order by user_id, mobile_num; MySQL

3.6K20

Oracle 分页查询与数据实例

rownum在过滤完之后会重新排行号,如果是romnum>n的话,过滤掉不满足条件的,重新排又从1开始还是不满足条件,再过滤最终会把所有数据都过滤掉 2.分页查询 --top n --查询工资排名前五的员工信息... --思路:先按工资进行排序,再根据行号过滤留下前5条记录  --因为SQL语句的执行顺序是先执行select返回查询结果(行号在此时排好)再进行排序  --所以先需要用子查询,返回排好序的查询结果...order by sal desc) t) where rown>5 and rown<=10; 3.rowid rowid 是Oracle中每个表都有的一个实际存在的一个值,rowid的值是唯一的 4.数据...test01 values(127,'张三'); insert into test01 values(128,'李四'); insert into test01 values(129,'张三'); --数据...--思路:重复项进行分组,获取每一组最小(或最大)的rowid,删除不在此列的数据 delete from test01 where rowid not in( (select min(rowid)

1.1K10

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券