测试环境:

create table bqh6 (xm varchar2(10),bmbh number(2),bmmc varchar2(15),gz int);
insert into bqh6 values ('张三',01,'技术支持',3500);
insert into bqh6 values ('李四',02,'研发',4500);
insert into bqh6 values ('王五',03,'外业测绘',5000);
insert into bqh6 values ('小崔',02,'研发',8000);
insert into bqh6 values ('钱六',01,'技术支持',5500);
insert into bqh6 values ('赵二',03,'外业测绘',4500);
select * from bqh6

create table bqh7 (xm varchar2(10),bmbh number(2),bmmc varchar2(15), gwjb varchar2(10));

insert into bqh7 values ('张三',01,'技术支持','C');
insert into bqh7 values ('李四',02,'研发','C');
insert into bqh7 values ('王五',03,'外业测绘','A');
insert into bqh7 values ('小崔',02,'研发','A');
insert into bqh7 values ('钱六',01,'技术支持','A');
insert into bqh7 values ('赵二',03,'外业测绘','B');
select * from bqh7

分组函数:max, min, avg, sum, count

查询工资最高和最低的人的姓名:

select '最高的:'||xm,gz from bqh6 where gz=(select max(gz)from bqh6) union all
select '最低的:'||xm,gz from bqh6 where gz=(select min(gz)from bqh6)

查询所有工资低于平均工资的人的信息:

select * from bqh6 where gz< (select avg(gz) from bqh6)

给所有低于平均工资的员工薪水上涨10%:

update bqh6 set gz=gz+(select avg(gz) from bqh6)*0.1 where gz< (select avg(gz) from bqh6);

commit;

select * from bqh6;

groupt by用于对查询结果分组统计

查询每个部门的平均工资和最高工资:

select avg(gz),max(gz),bmmc from bqh6 group by bmmc;

having子句用于限制分组结果显示

查询平均工资低于5000的部门名称和它的平均工资:

select bmmc,avg(gz) from bqh6 group by bmmc having avg(gz)<5000

注意:

分组函数(max,min,avg,count)只能出现在选择列表(select后),having和order by子句中;

如果select语句中同时包含group by,having和order by,他们的顺序必须是group by,having和order by (先分组→再抑制结果显示→最后分组);

在选择列中如果有列,表达式和分组函数,那么这些列和表达式必须有一个出现在group by子句中,否则就会报错。

----------------------------------------------------------------------------------

多表查询

查询雇员姓名及工资和所在部门的的岗位级别:

select a.xm,a.gz,b.gwjb from bqh6 a,bqh7 b where a.xm=b.xm

笛卡尔积,原则:多表查询的条件是至少不能少于表的个数-1

查询部门编号为10的部门名称、雇员姓名和工资:

select a.xm,b.bmbh,b.bmmc,a.gz from bqh6 a,bqh7 b where a.xm=b.xm and b.bmbh=2;

查询雇员姓名、工资以及所在部门名称并按部门排序

select a.xm,b.bmbh,b.bmmc,a.gz from bqh6 a,bqh7 b where a.xm=b.xm order by b.bmmc

order by 默认升序(asc),降序(desc)

子查询

.单行子查询

查询与张三同一部门的所有雇员姓名:

select a.xm from bqh6 a where a.bmmc=(select bmmc from bqh7 b where b.xm='张三')

 多行子查询

查询部门编号为3的雇员姓名、部门名称、工资:

all在多行子查询的使用:与每一个内容相匹配

查询工资比部门编号3的所有员工的工资高的雇员姓名、工资和部门名称:

>ALL:比子查询中返回的最大的记录还要大

<ALL:比子查询中返回的最小的记录还要小

①select xm,bmmc,gz from bqh6 where gz>all (select max(gz) from bqh6 where bmbh=3)

②select xm,bmmc,gz from bqh6 where gz>(select max(gz) from bqh6 where bmbh=3)

②的效率要高于①,因为①会逐条的对比,而②直接比较结果。

IN在子查询的使用:用于指定一个子查询的判断范围

查询部门编号为1的雇员姓名、部门名称及工资信息。

select * from bqh6 where gz in(select gz from bqh6 where bmbh=1);

any在多行子查询的使用:与每一个内容相匹配,有三种匹配形式

①=any:功能与IN操作符是完全一样的

②>any:比子查询中返回记录最小的还要大的数据

③<any:比子查询中返回记录最大的还要小的数据

FROM子句中使用子查询一般都是返回多行多列,可以将其当作一张数据表:

查询出每个部门的编号,名称,部门人数,平均工资

select a.xm,a.bmbh,a.bmmc,b.部门人数,b.平均工资 from bqh6 a,
(select bmbh bh,count(xm) 部门人数,avg(gz) 平均工资 from bqh6 group by bmbh) b
where a.bmbh=b.bh

注意:

当在from子句中使用子查询时,该子查询会被作为一个视图对待,因此叫做内嵌视图,当在from子句中使用子查询时,必须给子查询指定别名。给列取别名可以使用as,但是给表、视图、子查询起别名不可以用as

分页查询:ROWNUM为显示每一条记录动态自动生成行号。

为显示每一条记录动态自动生成行号

查询结果就会多出一列,rn,表示rownum,行号数,是Orcl分配的。

查询前条记录:

查询前3-6条记录:

Oracle的分页是最复杂的,要使用2次子查询,但效率也是最高的,因为内部使用了2分查找的原理。MySql的分页是最简单的,直接一个limit就实现了

orcl 复杂查询的更多相关文章

  1. orcl数据库查询重复数据及删除重复数据方法

    工作中,发现数据库表中有许多重复的数据,而这个时候老板需要统计表中有多少条数据时(不包含重复数据),只想说一句MMP,库中好几十万数据,肿么办,无奈只能自己在网上找语句,最终成功解救,下面是我一个实验 ...

  2. Orcl分页查询的语法示例

    Orcle分页查询SQL sql =  SELECT T.* FROM (SELECT X.*, ROWNUM AS RN FROM (SELECT * FROM +表名) X WHERE ROWNU ...

  3. 数据库---实验四 oracle的安全性和完整性控制

    实验内容: (一) 授权 . 以dba用户的身份登陆oracle,创建用户u1+学号后四位,u2+学号后四位. SQL> create user u1_3985 identified by &q ...

  4. Oracle 删除数据后释放数据文件所占磁盘空间

    测试的时候向数据库中插入了大量的数据,测试完成后删除了测试用户以及其全部数据,但是数据文件却没有缩小.经查阅资料之后发现这是 Oracle “高水位”所致,那么怎么把这些数据文件的大小降下来呢?解决办 ...

  5. DBlink 创建 删除 脚本

    --配置SQLSERVER数据库的DBLINK --删除dblink Exec sp_droplinkedsrvlogin test,Null Exec sp_dropserver test --创建 ...

  6. python 连接 oracle 统计指定表格所有字段的缺失值数

      python连接oracle -- qlalchemy import cx_Oracle as co import pandas as pd from sqlalchemy import crea ...

  7. 从零开始教你安装Oracle数据库

    1.数据库安装 1.1下载 根据自己的操作系统位数,到oracle官网下载(以oracle 11g 为例) 之后把两个压缩包解压到同一个文件夹内(需要注意的是,这个文件夹路径名称中最好不要出现中文.空 ...

  8. JDBC_part1_Oracle数据库连接JDBC以及查询语句

    本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! JDBC part1 JDBC概述 jdbc是一种用于 ...

  9. Mybatis框架的模糊查询(多种写法)、删除、添加(四)

    学习Mybatis这么多天,那么我给大家分享一下我的学习成果.从最基础的开始配置. 一.创建一个web项目,看一下项目架构 二.说道项目就会想到需要什么jar 三.就是准备大配置链接Orcl数据库 & ...

随机推荐

  1. Mysql - 增量脚本中修改字段属性

    在增量部署系统的时候, 经常需要提供增量修改的脚本, 如果是修改存储过程或者自定义函数, 那还是很好改的, 不用担心表功能收到影响. 如果是改字段呢? 首先不知道字段是不是已经在系统里面, 没有的话, ...

  2. GCC 多文件编辑

    #include <stdio.h> int plus(int a, int b); int minus(int a, int b); int multiply(int a, int b) ...

  3. cool--music

    1.三年的赌注 2.非酋 3.Swan Song 4.Better Than A Hallelujah

  4. 比較C struct 與 C# unsafe struct内存分佈

    昨晚在群裏無意間看到一個朋友有一個需求.他是在C裏面將兩個結構體(HeadStruct,BodyStruct)的内存數據直接通過socket send發給C#寫的服務端來處理.當然他之前所使用的需求基 ...

  5. element-ui2源码修改小问题

    最近element-ui升级到2了,添加了不少功能,可喜可贺,可喜可贺! 然而,产品的需求依然那么刁钻,上传与删除图片还是要去改源码,为了同时用新的ele,决定在2中改源码 然而,遇到问题了. 一开始 ...

  6. [转]单据套打WINFORM实现,带预览功能

    本文转自:https://blog.csdn.net/lyflcear/article/details/22795053 昨天公司要打单子而不是以前的手写 为了实现这样的功能上网搜索了一下 http: ...

  7. C#中,Json的序列化和反序列化的几种方式总结

    在这篇文章中,我们将会学到如何使用C#,来序列化对象成为Json格式的数据,以及如何反序列化Json数据到对象. 什么是JSON? JSON (JavaScript Object Notation) ...

  8. [javaSE] 看博客学习多线程的创建方式和优劣比较和PHP多线程

    通过实现Runnable接口创建线程 获取Thread对象,new出来,构造函数参数:Runnable对象 Runnable是一个接口,定义一个类MyRunnable实现Runnable接口,实现ru ...

  9. JVM 内存初学 (堆(heap)、栈(stack)和方法区(method) )(转载)

    想想面试的时候很多会问jvm这方面的问题虽然还是菜鸟不太能用到现在但是还是了解一下, 找资料的时候看见个大佬写的很好转载到这方便以后自己复习和给大佬做宣传 以下为大佬的博客原文: 这两天看了一下深入浅 ...

  10. Tomcat Connector原理

    Tomcat工作原理 要了解其中的工作原理我们首先看如下两个图 Tomcat基本架构图: Tomcat请求示意图: 客户端的请求通过Connector接受处理后在到容器Engine->Host- ...