您的位置 首页 > 数码极客

oracle如何取最大值—oracle取最大值函数prival…

概述

今天主要整理了4道Oracle 经典面试题,与大家分享学习。下面一起看看详细的介绍吧


第一题

1、测试数据

create table test( id number(10) primary key, type number(10) , t_id number(10), value varchar2(6) ); insert into test values(100,1,1,'张三'); insert into test values(200,2,1,'男'); insert into test values(300,3,1,'50'); insert into test values(101,1,2,'刘二'); insert into test values(201,2,2,'男'); insert into test values(301,3,2,'30'); insert into test values(102,1,3,'刘三'); insert into test values(202,2,3,'女'); insert into test values(302,3,3,'10'); commit; select * from test;

2、需求:

根据以上的表写出一条查询语句,查询结果如下:

3、实现:

/* 根据表格可以分析出type列中1代表姓名、2代表性别、3代表年龄,而t_id中id一样的为同一个人的属性,查询结果中列依次为姓名、性别、年龄,而type列决定姓名、性别、年龄 */ /*使用分组,先对t_id进行分组,然后用decode函数过滤数据,例:decode(type, 1, value) type=1就显示为value 由于分组后select后面的列字段只能是分组的字段或者组函数,所有使用max()。 同一个人的type没有重复数值所以 decode(type, 1, value)返回的值只有一个,最大值也就是这个值 */ select max(decode(type, 1, value)) "姓名", max(decode(type, 2, value)) "性别", max(decode(type, 3, value)) "年龄" from test group by t_id; /*使用连表,通过where过滤生成3张type分别等于1(姓名)、2(性别)、3(年龄)的3张虚拟表 再通过where 连接条件 三张表t_id相等的为同一个人或者说同一条记录(行) */ select "姓名", "性别", "年龄" from (select value,t_id from test where type=1) t1, (select value,t_id from test where type=2) t2, (select value,t_id from test where type=3) t3 where and ;

第二题

1、测试数据

create table tmp(rq varchar2(10),shengfu varchar2(5)); insert into tmp values('2019-07-09','胜'); insert into tmp values('2019-07-09','胜'); insert into tmp values('2019-07-09','负'); insert into tmp values('2019-07-09','负'); insert into tmp values('2019-07-10','胜'); insert into tmp values('2019-07-10','负'); insert into tmp values('2019-07-10','负'); commit; select * from tmp;

2、需求:

如果要生成下列结果, 该如何写sql语句?

3、实现:

--使用分组 --按日期分组,用conut函数计算次数 select rq "日期", count(decode(shengfu, '胜', 1)) "胜", count(decode(shengfu, '负', 1)) "负" from tmp group by rq order by rq; --使用连表 --这道题本身就需要分组,不建议使用连表做 select .胜, t2.负 from (select count(decode(shengfu, '胜', 1)) "胜", rq from tmp group by rq) t1 join (select count(decode(shengfu, '负', 1)) "负", rq from tmp group by rq) t2 on ;

第三题

1、测试数据

create table STUDENT_SCORE ( name VARCHAR2(20), subject VARCHAR2(20), score NUMBER(4,1) ); insert into student_score (NAME, subject, SCORE) values ('张三', '语文', 78.0); insert into student_score (NAME, SUBJECT, SCORE) values ('张三', '数学', 88.0); insert into student_score (NAME, SUBJECT, SCORE) values ('张三', '英语', 98.0); insert into student_score (NAME, SUBJECT, SCORE) values ('李四', '语文', 89.0); insert into student_score (NAME, SUBJECT, SCORE) values ('李四', '数学', 76.0); insert into student_score (NAME, SUBJECT, SCORE) values ('李四', '英语', 90.0); insert into student_score (NAME, SUBJECT, SCORE) values ('王五', '语文', 99.0); insert into student_score (NAME, SUBJECT, SCORE) values ('王五', '数学', 66.0); insert into student_score (NAME, SUBJECT, SCORE) values ('王五', '英语', 91.0); commit; select * from STUDENT_SCORE;

2、需求:

有一张表,里面有3个字段:语文,数学,英语。其中有3条记录分别表示语文70分,数学80分,英语58分,请用一条sql语句查询出这三条记录并按以下条件显示出来(并写出您的思路): 大于或等于80表示优秀,大于或等于60表示及格,小于60分表示不及格。

3、实现

--使用分组 select name "姓名", max(decode(subject, '语文' ,score)) "语文", max(decode(subject, '数学' ,score)) "数学", max(decode(subject, '英语' ,score)) 英语 from STUDENT_SCORE group by name; --使用连表 select 姓名, 语文, 数学, 英语 from (select name,score from STUDENT_SCORE where subject='语文') t1 join (select name,score from STUDENT_SCORE where subject='数学') t2 on =t2.name join (select name,score from STUDENT_SCORE where subject='英语') t3 on =t3.name; --在分组的基础上使用 case when then esle end select t.姓名, (case when t.语文>=80 then '优秀' when t.语文>=60 then '及格' else '不及格' end) 语文, (case when t.数学>=80 then '优秀' when t.数学>=60 then '及格' else '不及格' end) 数学, (case when t.英语>=80 then '优秀' when t.英语>=60 then '及格' else '不及格' end) 英语 from (select 姓名, 语文, 数学, 英语 from (select name,score from STUDENT_SCORE where subject='语文') t1 join (select name,score from STUDENT_SCORE where subject='数学') t2 on =t2.name join (select name,score from STUDENT_SCORE where subject='英语') t3 on =t3.name ) t;

第四题(这道题难度相对较高)

1、测试数据:

create table yj01( month varchar2(10), deptno number(10), yj number(10) ); insert into yj01(month,deptno,yj) values('一月份',01,10); insert into yj01(month,deptno,yj) values('二月份',02,10); insert into yj01(month,deptno,yj) values('二月份',03,5); insert into yj01(month,deptno,yj) values('三月份',02,8); insert into yj01(month,deptno,yj) values('三月份',04,9); insert into yj01(month,deptno,yj) values('三月份',03,8); create table yjdept( deptno number(10), dname varchar2(20) ); insert into yjdept(deptno,dname) values(01,'国内业务一部'); insert into yjdept(deptno,dname) values(02,'国内业务二部'); insert into yjdept(deptno,dname) values(03,'国内业务三部'); insert into yjdept(deptno,dname) values(04,'国际业务部'); select * from yj01; select * from yjdept;

2、需求:

从前面两个表中取出如下图所列格式数据。

3、实现:

--使用分组 select deptno, max(decode(month,'一月份',yj)) 一月份, max(decode(month,'二月份',yj)) 二月份, max(decode(month,'三月份',yj)) 三月份 from yj01 group by deptno order by deptno; --这道题给出了两张表,而用分组做,使用yj01表就能做出来了,所以这道题考察的应该是连表的知识 /*这两张表中有的月份有的部门业绩是空的,而用前几道题的做法,不匹配条件的值会被过滤掉,例如month=一月份的只有1部门,形成的表里deptno只有1和二月份、三月份形成的表中的deptno无法匹配 而yjdept表中包含了所有部门编号deptno,这时就可以用到外连接的特性 (在满足一张表的内容都显示的基础上,连接另外一张表,如果连接匹配则正常显示,连接不匹配,另外一张表补null) */ select , 一月份, 二月份, 三月份 from (select y2.deptno,y1.yj from (select yj, deptno from yj01 where month='一月份') y1 right join yjdept y2 on y1.deptno=y2.deptno)t1 join (select y2.deptno,y1.yj from (select yj, deptno from yj01 where month='二月份') y1 right join yjdept y2 on y1.deptno=y2.deptno)t2 on =t2.deptno join (select y2.deptno,y1.yj from (select yj, deptno from yj01 where month='三月份') y1 right join yjdept y2 on y1.deptno=y2.deptno)t3 on =t3.deptno order by ;

这四个表都是有点难度的,值得深入学习一下。后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注一下~


责任编辑: 鲁达

1.内容基于多重复合算法人工智能语言模型创作,旨在以深度学习研究为目的传播信息知识,内容观点与本网站无关,反馈举报请
2.仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证;
3.本站属于非营利性站点无毒无广告,请读者放心使用!

“oracle如何取最大值,oracle取最大值函数prival,oracle取最大值的那一行,oracle取最大值的记录,oracle取最大值函数”边界阅读