2019-04-02oracle 第二部分

转换函数 数值转字符 字符转数值 日期
字符转数值 to_number(str)
SELECT 100+'10' from dual; 110 默认已经帮我们转换
SELECT 100+to_number('10') from dual; 110
数值转字符
SELECT to_char(sal,'$99.99 ')from emp;
日期转字符 to_char()
selectt to_char(sysdate,'yyy-mm-dd hh:mi:ss') from dual;
只想要年
SELECT to_char(SYSDATE,'yyyy')from dual;2017
只想要日
SELECT to_char(sysdate,'d')from dual;
SELECT to_char(sysdate,'dd')from dual;
SELECT to_char(sysdate,'ddd')from dual;
SELECT to_char(sysdate,'day') from dual; monday
select to_char(sysdate,'dy')from dual;mon 星期的简写

字符转日期
select to date('2017-04-10','yyyy-mm-dd') from dual;
查询1981年--1985年入职的员工信息
select * from emp where hiredate between to_date('1981','yyyy') and to_date('1985','yyyy');
通用函数 nvl(参数1,参数2)如果参数1=nulL 就返回参数2
nvl2(参数1,参数2,参数3) 如果参数1=null ,就返回参数3
select nv12(null,25,5) from dual; 5
select nv12(1,5,6) from dual 5
nul1if(参数1,参数2) 如果参数1=参数2 就返回null
coalesce: 返回第一个不为null的值
SELECT nullif(5,6) from dual;5
SELECT nullif(5,5) from dual;null
SELECT coalesce(null,null,3,5.6)from dual;
条件表达式
case字段:
when 值1 then 值
when 值2 then 值
else
默认值
end
给表中姓名取一个中文名
select
case ename
when 'smith' then '刘备小二'
when 'allen' then '诸葛村夫'
ELSE
'路人甲'
end
from emp;
case .. when 通用的写法 mysql 和oracle 中都可以使用

Oracle 特有的写法: decode(字段,if1,then1,if2,then2,else1)
给表中姓名取一个中文名
SELECT decode(ename,'smith','刘备小二','allen','诸葛村夫,)from emp
分组表达式 group by
select 分组的条件,分组之后的操作 from 表名 group by分组的条件 having 条件过滤
分组统计所有部门的平均工资,找出平均工资大于1500的部门
select deptno,avg(sal) from emp group by deptno;
过滤出大于2000的
select deptno,avg(sal) from emp group by deptno having avg(sal)2000;
select deptno,avg(sal) from emp group by deptno having avg(sal)2000;
sql的编写顺序
select from where groupby having orderby
sql的执行顺序
from where groupby having select orderbv
where 和 having 区别
where 后面不能接聚合函数,可以接单行函数
having 是在groupby之后只想,可以接聚合函数
select * from bonus;
select * from salgrade;
多表查询“” 迪卡尔积 实际上市两、张表的乘积,但是实际开发中没有太大意义

格式 select * from 表1,表2
select * from emp e1,dept d1 where e1.deptno=d1.deptno;
内连接 隐士内连接
等值内连接: where e1.deptno=d1.deptno;
不等值内连接: where e1.deptno<>d1.deptno;
自连接: 自己连接自己
显示内连接

查询员工编号,姓名,员工部门名称经理的编号,姓名
select e1.empno,e1.ename,e1.mgr from emp e1,emp m1 where e1.mgr=m1.empno;
查询员工编号,员工姓名,员工的部门,员工的部门名称,经理的编号,姓名
e1.deptno=d1.deptno
select e1.empno,e1.ename,e1.mgr from emp e1,emp m1 where e1.mgr=m1.empno;
查询员工编号,员工姓名,员工的部门名称,经理的编号,经理的姓名,经理的部门名称
select e1.empno, case e1.ename
when 1 then '一级'
when 2 then '二级'
else '五级'
end "等级"
,d1.dname,e1.mgr,m1.ename,d2.dname from emp e1 ,emp m1,dept d1,
dept d2, salgrade s1 where e1.mgr=m1.empno and e1.deptno=d1.deptno and m1.deptno =d2.deptno,
and e1.sal between s1.losal and s1.hisal
select * from salgrade;
查询员工姓名和员工部门所处的位置
select e1.ename,d1.loc from emp e1,dept d1 where e1.deptno=d1.deptno

显示内连接
select * from 表1 inner join 表2 inner可以省略
select * from emp e1 inner join dept d1 on e1.deptno=d1.deptno
外连接 左外连接
坐表中所有的记录,如果右表 没有对应的记录,就显示空
右外连接
left outer join 右外连接 right outer join outer 关键字可以省略
select * from emp e1 left outer join dept d1 on e1.deptno=d1.deptno;

insert into emp(empno,ename) values (9527,'huaan')
select * from emp e1 right outer join dept d1 on e1.deptno=d1.deptno
oracle 中的外连接:(+)实际上是如果没有对应的记录就加上空值
select * from emp e1,dept d1 where e1.deptno =d1.deptno(+);
select * from emp e1,dept d1 where e1.deptno(+)=d1.deptno;
子查询 查询语句中嵌套查询语句
查询员工最高工资的员工信息
用来解决复杂的查询语句
单行子查询: 》 》= = 《 《= <> !=

多行子查询
1.查询出最高工资
select max(sal) from emp; 5000
2.工资等于最高工资
select * from emp where sal=(elect max(sal) from emp);
查询出比雇员7654的工资高,同时和7788从事相同的工作的员工信息
雇员7654的工资1250
select sal from emp where empno=7654;
7788从事的工作
select job from emp where empno=7788;
两个条件合并
select * from emp where sal>1250 and job='anlyst';

select * from emp where sal>(select sal from emp where empno=7654) and job=(select * from emp where sal>1250 );

查询每个部门最低工资的员工信息和他所在的部门信息
知道每个部门的最低工资 分组统计
select deptno min(sal) from emp groupby deptno
员工工资等于他所处部门的最低工资
select * from emp e1,
(select deptno min(sal) from emp groupby deptno)t1
where e1.deptn=t1.deptno and e1.sal=t1.minsal;
查询部门相关信息
select * from emp e1,
(select deptno min(sal) from emp groupby deptno)t1,dept d1
where e1.deptn=t1.deptno and e1.sal=t1.minsal and e1.deptnp=d1.deptno;
查询不是领导的信息
select * from emp where empno in (select mgr from emp);
select * from emp where empno <>all (select mgr from emp);
正确的写法
select * from emp where empno in (select mgr from emp where mgr is not null);
通常情况下,数据库中不要出现null 最好的做法加上notnull
null值并不代表不占空间 char(100)null 100个字符
exists(查询语句):存在的意思
当作布尔值来处理:当查询语句有结果的时候就是返回true否则返回的事false
数据量比较大的时候是比较高效的
select * from emp where exists(select * from emp where deptno =1234567);
select * from emp where 3=4;
select * from emp where exists(select * from emp where deptno=20);
查询有员工的部门信息
select * from dept d1 where exists(select * from emp e1 where e1.deptno=d1.deptno);
找到员工工资最高的前三名(降序排序)
select * from emp order by sal desc;
rownum:伪列,系统自动生成的一列,用来表示行号的
rownum 是oracle中特有的用来表示行号的,默认值1起始值是1,在查询出结果之后,再添加1
select rownum, e1.* from emp e1;
查询rownum大于2的所有记录,默认起始值是1 没有任何记录
rownum最好不要于号判断,可以做小于好判断
select rownum,* rom emp e1 where rownum>2;
查询rownum大于等于1的所有记录
select rownum,* rom emp e1 where rownum>=1;
查询rownum<6的所有记录
select rownum,e1.* from emp e1 where rownum<6
rownum排序
select rownum,e1.* from emp e1 order by sal;
sql执行顺序
from where groupby having select rownum order by
找到员工表中工资最高的前三名
select 31.* from emp e1 order by sal de
将上面的结果当做一张表处理,再查询
select rownum t1.* from (select 31.* from emp e1 order by sal de) t1;
只要显示前三条记录
select rownum t1.* from (select 31.* from emp e1 order by sal de) t1 where rownum<4;
找到员工中薪水大于本部门平均薪水的员工
所有部门的平均薪水 分组统计
select deptno,avg(sal) from emp group by deptno;
员工工资>本部门平均工资
select * from emp e1,(select deptno,avg(sal)t1rom emp group by deptno;)t1
where e1.deptno=t1.deptno and e1.sal> t1.avgsal;
关联子查询,非关联子查询
select * from emp e where sal >(select avg(sal) from emp e2 group by deptno) t1
having e.deptno =e2.deptno);
统计每年入职的员工个数
select hiredate from emp;
只显示年
select to_char (hiredate,'yyyy') from emp;
分组统计
select to_char (hiredate,'yyyy'yycount(1 )ccm emp group by to_char(hiredate,'yyyy')
将1980年竖起来
select sum(
case yy
when '1987' then cc end )1987"
rom
(select to_char (hiredate,'yyyy'yycount(1 )ccm emp group by to_char(hiredate,'yyyy') )
将1980年竖起来 并且取一个别名 1987
去除行记录中的空值
统计员工的总数
select sum (cc) "total" from
将1987和total合并在一起
显示所有年份的结果
rowid 伪列 每行记录所存放的真实物理地址
rownum:行号,每查询出记录之后,就会添加一个行号
select rowid,e.* from emp e;
去除表中重复记录
creat table p(name varchar2(10) );
insert into p values('黄伟福');
select * from emp;
删除表中重复记录,只保留了rowid最小的那行记录
select rowid,p.* from emp;
select distinct * from p;
delete from p where
select min(rowid) from p2 where p1.name =p2.name
delete from p1 where p1.name=p2.name
delete from p1 where p1.rowid>(select min(rowid) from p2 where p1.name =p2.name)
rownum:分页查询
查询第6条-第10条记录
在oracle中只能使用查询来做分页查询

select rownum,emp.* from emp;

select rownum,emp.* from emp;
select rownum hanghao ,emp.* from emp;
select * from (select rownum hanghao ,emp.* from emp;) tt where tt.hanghao between 6 and 10;
集合运算:并集 将两个查询结果进行合并
交集
差集
工资大于1500 或者20号部门下的员工
select * from emp where sal>1500 or deptno=20;
工资大于1500
select * from emp where sal >1500
20号部门下的员工
select * from emp where deptn0 =20;
并集运算 union union all
select * from emp where sal >1500
union
select * from emp where deptn0 =20; 9条

select * from emp where sal >1500
union all
select * from emp where deptn0 =20; 12条
union:去除重复的,并且排序
union all:不会去除重复的
所有的查询结果可能不是来自同一张表
基本信息,详细信息
emp 2000年
2017年 手机 详细信息 emp2017
差集运算:两个结果相减
查询1981年入职员工(不包括总裁和经理)
select * from emp where to_char(hiredate,'yyyy')=1981;
总裁和经理
select * from emp where job='president' or 'manager';
select * from emp where to_char(hiredate,'yyyy')=1981;
minus
select * from emp where job='president' or 'manager';

select * from emp where to_char(hiredate,'yyyy')=1981;
minus
select * from emp where job='president' or 'manager';
集合运算中的注意事项
列的类型要一致
按照顺序写
列的数量要一致
如果不足,用空值填充
select * from emp where to_char(hiredate,'yyyy')=1981;
union
select * from emp where job='president' or 'manager';

select ename,sal,deptno from emp where sal>1500
union
select ename,sal, from emp where deptno=20;

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容

  • 幕课oracle学习笔记 --!!!scott用户 --一.分组查询 --1.常用的分组函数:AVG(平均数),S...
    xiaoxiao苏阅读 1,260评论 0 5
  • 1. select * from emp; 2. select empno, ename, job from em...
    海纳百川_4d26阅读 1,897评论 0 4
  • 最近对谈判感触较深,聊一聊关于商业谈判的几个知识点,双赢谈判、权力有限以及谈判期限策略,与诸位分享。 ...
    口口松阅读 1,397评论 0 3
  • 我这里在下雨 你那里怎么样 是否好些了 找到了对的生活对的人 而且学着冷酷一点? 我确实还过的可以 工作充实伙食合...
    老晁阅读 170评论 0 2
  • 打卡日期:2019年/3月/28日 90天打卡累计天数:59/90 #宣言:爱是教育的基础# 孩子第二个30天目标...
    张艺妈妈阅读 91评论 0 0