本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用.

**转载请注明 出自 : luogg的博客园 ** 谢谢配合!

day03_条件查询_排序_函数

  • 清空回收站: PURGE recyclebin;
  • 给表名,字段加别名 : 表名 + 别名 ; 字段 [as] 别名 ;
  • 去重复 : select distinct first_name from employees;

    删除重复数据 :

    方法1,先查找不重复的,再复制一份查询后不重复的

    方法2,用rowID方法

条件查询与排序

where 语法 中的比较运算符

= , > , < , >= , <= , <>或!= , between and(中间值) , in(匹配多个值中任意一个,代替了OR) , like(模糊查询%_) , is null

逻辑运算符

not,and, or,

优先级: not > and > or

排序 order by(asc,desc)

  • 默认是asc升序排列.

    select * from copy_emp order by employee_id;--按员工id从小到大序
  • 降序排列,desc

    select * from copy_emp order by employee_id desc;
  • 降序时,null值会放到第一位, 需要将它方法最后,或者用0代替

    select * from copy_emp order by employee_id desc nulls last;

    select nvl(department_id,0) from copy_emp order by employee_id;
  • 空值为最小值.
  • 字符串排列原则 : A -> Z ,之后 a -> z;

函数

单行函数

字符函数

大小写转换函数

  1. LOWER.将大写或小写混合的字符转换成小写
  2. UPPER.将大写或小写混合的字符转换成大写
  3. INITCAP.将每个单词的第一个字母转换成大写,其余字母都是转换成小写

    Eg:select initcap(te_name) from weixin_te_msg;

字符处理函数

  1. CONCAT.将字符串连接在一起

    select concat('哈哈','呵呵') from dual; - -哈哈呵呵
  2. SUBSTR.提取字符串的某一特定部分

    select substr('wqedsadsa',1,3) from dual; - -wqe
  3. LENGTH.返回字符串的长度

    select length('哈哈') from dual; - -2
  4. LPAD.右对齐,填充在前边
  5. RPAD.左对齐,填充在后边

    select rpad ('150',10,'') from dual; - -150******
  6. TRIM.去除字符串头部和尾部的字符

    select trim('S' from first_name) from copy_emp;

数值函数

  • round.(数值,从第几位开始取)

    将列或表达式所表示的数值四舍五入到小数点后的第n位
  • trunc.(数字,从第几位开始)

    将列或表达式所表示的数值截取到小数点后的第n位

日期函数

  • ADD_MONTHS(日期,数字): 在日期上加上一定的月份
  • LAST_DAY(日期): 该日期的最后一天
  • MONTHS_BETWEEN(日期1,日期2) : 两个月之间的天数
  • NEXT_DAY(d,char) : 返回day日期之后的日期, char为数字或字符串
  • 日期-日期, 为天数
  • 日期+/- 数字 , 为日期

数值格式

滤空函数(如果字符串为空则替换)

nvl(expr1,expr2);

可以使用nvl转换任何类型的数据, 但是表达式1和2的数据类型必须一致

select nvl(salary,0) from copy_emp; - -查询salary,为空用0替代

decode函数

给部门 50 的员工涨工资 200 元, 给部门 80 的涨工资 300 元, 其余的不涨 .

select,department_id,salary,decode(department_id,50,salary+200,80,salary+300,salary) as "涨后工资" from copy_emp;

case when 函数

工资0-3000之间,第三等级,3000-5000 第二等级, 5000以上 , 第一等级.

select salary,(case when salary<=3000 then '第三等级' when salary>3000 and salary<=5000 then '第二等级' when salary>5000 then '第一等级' when salary is null then '无' end) as "工资等级" from copy_emp;

decode函数和case when 函数对比 :

  1. DECODE Oracle 特有;
  2. CASE WHEN Oracle , SQL Server, MySQL 都可用;
  3. DECODE 只能用做相等判断

    CASE 可用于=,>=,<,<=,<>,is null,is not null 等的判断;

多行函数

组函数

**按雇员所在部门统计各部门内雇员的平均工资: **

SELECT department_id,AVG(salary) FROM copy_emp GROUP BY department_id;

按所在部门及从事的工作分组统计平均工资:

SELECT department_id,job_id,avg(salary) FROM copy_emp GROUP BY department_id,job_id;

day04_子查询

1.单列子查询

2.多列子查询

--查询显示和 Donald 同部门且同工作岗位的员工姓名、工作岗位、工资、部门编号
select first_name||'-'||last_name as "姓名",job_id,salary,department_id
from copy_emp where (department_id,job_id)=(
select department_id,job_id from copy_emp where
first_name='Donald');
--查询大于所在部门平均工资的雇员的姓名、工资、部门编号以及所在部门的平均工资
select first_name||'-'||last_name as "姓名",salary,emp.department_id
from copy_emp emp,(select department_id,avg(salary) avgsal
from copy_emp group by department_id) d
where emp.department_id=d.department_id
and salary>avgsal;

3.单行子查询 : 子查询只返回一行.

--任务一: 查询出比编号151雇员工资高的其他雇员
select * from copy_emp where salary>(select salary from copy_emp where employee_id=111);
--任务二: 显示和雇员151从事相同工作并且工资大于雇员123的雇员的姓名和工作
select first_name||','||last_name as "姓名", job_id from copy_emp
where job_id=(select job_id from copy_emp where employee_id = 111)
AND salary>(select salary from copy_emp where employee_id = 112);
--任务三: 显示工资最低的雇员的姓名、工作、和工资
select first_name||'-'||last_name as "姓名" , job_id,salary from copy_emp
where salary = (select min(salary) from copy_emp );
--任务四: 显示部门内最低工资比100 部门最低工资要高的部门编号以及部门内最低工资
select department_id,min(salary) from copy_emp group by department_id having min(salary)>(
select min(salary) from copy_emp where department_id = 100);

4.多行子查询

  • IN:等于列表中的任意一个
  • ANY:

    小于某集合中的任意一个值,就是小于集合中的最大值。

    大于某集合中的任意一个值,就是大于最小值。
  • ALL:

    小于某集合中的所有值,就是小于最小值。

    大于某集合中的所有值,就是大于最大值。
--查询工资与任何一个部门最低工资相等的雇员姓名,工资
select first_name||'-'||last_name as "姓名" ,salary from copy_emp where salary in(
select min(salary) from copy_emp group by department_id);
--显示只要比某个IT工资低但又不是IT 工作的雇员姓名,职位id,工资
select first_name||'-'||last_name as "姓名" ,job_id,salary from copy_emp
where salary<any(select salary from copy_emp where job_id = 'IT_PROG')
and job_id <>'IT_PROG';
--显示工资大于所有部门平均工资的雇员雇员姓名,工资
select first_name||'-'||last_name as "姓名",salary from copy_emp
where salary>any(select avg(salary) from copy_emp);

课外补充 :

--工资表中前三的员工
select rownum,first_name ,last_name, salary from (
select first_name,last_name,salary from copy_emp order by salary desc nulls last
) where rownum<=3; rownum是一个伪列, 表示记录在结果集中的行号,
1,rownum一旦生成, 就不会变化,
2,对于rownum,只能使用<和<=, 不能使用>和>=. 查询我的经理的工资:
select empno,ename,sal my_sal,mgr,(select sal from emp where
empno=e.mgr) as mgr_sal from emp e;

Oracle学习总结_day03_day04_条件查询_排序_函数_子查询的更多相关文章

  1. MySQL开发——【联合查询、多表连接、子查询】

    联合查询 所谓的联合查询就是将满足条件的结果进行拼接在同一张表中. 基本语法: select */字段 from 数据表1 union [all | distinct] select */字段 fro ...

  2. (五)连接查询(SQL99标准)、子查询、分页查询、联合查询

    一.连接查询(SQL99标准) 1.含义:当要查询的数据来自多张表时要使用连接查询 2.语法: select 查询列表 from 表1 别名 [连接类型] join 表2 别名 on 连接条件 [wh ...

  3. Hibernate 笔记 HQL查询 条件查询,聚集函数,子查询,导航查询

    在hibernate中进行多表查询,每个表中各取几个字段,也就是说查询出来的结果集并没有一个实体类与之对应,如何解决这个问题? 解决方案一,按照Object[]数据取出数据,然后自己组bean 解决方 ...

  4. java:Oracle(级联删除,左右内外交叉自然连接,子查询,all,any,in)

    1.级联删除: -- 级联删除:裁员,公司倒闭 -- 级联删除(cascade),设置为null(setnull),放任不管(No action) -- cascade:(以一对多为例)如果删除多的一 ...

  5. 逆袭之旅DAY14.东软实训.Oracle.多表连接、分组函数、子查询

    2018-07-10 08:29:55 思考应用场景 异常数据的测试 6.显示能挣得奖金的雇员的姓名.工资.奖金,并以工资和奖金降序排列.select ename,sal,commfrom empWH ...

  6. oracle 子查询 where having from ,from子查询提高效率

    where 子查询主要功能是控制数据行的,返回结果一般都是单行单列.多行单列.单行多列数据 单行单列 SELECT * FROM emp WHERE hiredate=( SELECT MIN(hir ...

  7. Hibernate 函数 ,子查询 和原生SQL查询

    一. 函数 聚合函数:count(),avg(),sum(),min(),max() 例:(1)查询Dept表中的所有的记录条数. String hql=" select count(*) ...

  8. insert into select 引起的 "子查询返回的值不止一个。当子查询跟随在**之后,或子查询用作表达式时,这种情况是不允许的"

    目录 1.事故现场 1.1 在使用 Insert into Table2 select * from Table1 将表1的数据插入到表2时,报错如下: 1.2 sql 语句 2.推测 3.解决方案 ...

  9. SQL相关子查询是什么?和嵌套子查询有什么区别?

    目录 两者的各种叫法 相关子查询MySQL解释 相关子查询Wikipedia解释 相关子查询执行步骤拆解 相关子查询和嵌套查询的区别 参考资料 两者的各种叫法 相关子查询叫做:Correlated S ...

随机推荐

  1. Web3DGame之路,Babylonjs 和TypeScript学习笔记(二)

    先来认识一下Babylonjs,由于基于webgl来开发,所以先介绍一下基础知识. Webgl是一个html标准,他要在canvas元素上初始化. Html页面上的准备 所以我们先从html页面开始看 ...

  2. Gitcafe绑定自定义域名

    之前将自己练习写作工具替换为Markdown,部署工具改为Hexo,并且将托管地搬家到GitCafe之后,便是被各种的舒爽所围绕.具体折腾的详情参见使用Hexo搭建专属Blog.她们的组合方便快捷,让 ...

  3. Mesh Data Structure in OpenCascade

    Mesh Data Structure in OpenCascade eryar@163.com 摘要Abstract:本文对网格数据结构作简要介绍,并结合使用OpenCascade中的数据结构,将网 ...

  4. 静态Include和动态Include测试并总结

    主要代码 hjzgg.css .center-div{ width:auto; margin-left: 40%; margin-right: 40%; display: block; positio ...

  5. etlpy: 并行爬虫和数据清洗工具(开源)

    etlpy是python编写的网页数据抓取和清洗工具,核心文件etl.py不超过500行,具备如下特点 爬虫和清洗逻辑基于xml定义,不需手工编写 基于python生成器,流式处理,对内存无要求 内置 ...

  6. Rust初步(五):Rust与C#性能比较

    我学习Rust的目的并不是说期望用它来取代掉现有的开发平台或语言.相反,我认为当前绝大部分研发团队,都不可能只用一个平台或者一个语言. 当组织增长,他们越来越依赖大量的编程语言.不同的编程语言有不同的 ...

  7. RESTful API URI 设计: 查询(Query)和标识(Identify)

    相关文章:RESTful API URI 设计的一些总结. 问题场景:删除一个资源(Resources),URI 该如何设计? 应用示例:删除名称为 iPhone 6 的产品. 是不是感觉很简单呢?根 ...

  8. Oracle普通表->分区表转换(9亿数据量)

    背景介绍: 环境:Linux 5.5 + Oracle 10.2.0.4 某普通表T,由于前期设计不当没有分区,如今几年来的数据量已达9亿+, 空间占用大约350G,在线重定义为分区表不现实,故采取申 ...

  9. 在Linux下的中断方式读取按键驱动程序

    // 在Linux下的中断方式读取按键驱动程序 //包含外部中断 休眠 加入poll机制 // 采用异步通知的方式 // 驱动程序发 ---> app接收 (通过kill_fasync()发送) ...

  10. (三)WebGIS前端地图显示之根据地理范围换算出瓦片行列号的原理(核心)

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.前言 在上一节中我们知道了屏幕上一像素等于实际中多少单位长度(米或 ...