首页 Oracle第二章习题及答案

Oracle第二章习题及答案

举报
开通vip

Oracle第二章习题及答案------------------------------------------作者xxxx------------------------------------------日期xxxxOracle第二章习题及答案【精品文档】【精品文档】【精品文档】【精品文档】【精品文档】【精品文档】一、基于自己创建表的操作1:创建一张学生表student,拥有stuid,stuname,sex,三个字段,其中stuid为主键。createtablestudent(stuidintprimarykey,stunameVARC...

Oracle第二章习题及答案
------------------------------------------作者xxxx------------------------------------------日期xxxxOracle第二章习 快递公司问题件快递公司问题件货款处理关于圆的周长面积重点题型关于解方程组的题及答案关于南海问题 答案 八年级地理上册填图题岩土工程勘察试题省略号的作用及举例应急救援安全知识车间5s试题及答案 【精品文档】【精品文档】【精品文档】【精品文档】【精品文档】【精品文档】一、基于自己创建表的操作1:创建一张学生表student,拥有stuid,stuname,sex,三个字段,其中stuid为主键。createtablestudent(stuidintprimarykey,stunameVARCHAR(20),sexVARCHAR(20))2:为该表增加一个新列score。altertablestudentadd(scorevarchar(10));3:修改该表score列名为stuscore。altertablestudentrenamecolumnscoretostuscoree;4:为student表插入5条记录。insertintostudentvalues(1,'张三丰','男',80);insertintostudentvalues(2,'阿悄','女',70);insertintostudentvalues(3,'陈龙','男',90);insertintostudentvalues(4,'章子怡','女',50);insertintostudentvalues(5,'张卫健','男',60);5:查询student表中的全部数据,其中列名为中文。selectSTUIDas学号,STUNAMEas姓名,SEXas性别,STUSCOREEas分数fromstudent;6:查询学生姓名和分数,并是查询结果按照学生成绩降序排列。selectSTUNAME,STUSCOREEfromstudentorderbySTUSCOREEdesc;7:修改所有性别为“男”的学生信息为性别为“male”。updatestudentsetSEX='male'whereSEX='男';8:删除所有记录。deletefromstudent;9:删除student表。droptablestudent;二、基于emp表的操作1:创建一张新表emp1,和emp表结构和记录完全一样。createtableemp1asselect*fromScott.Emp;基于emp1表的操作:1:选择部门30中的雇员。select*fromemp1whereDEPTNO=30andJOB='CLERK';2:列出所有办事员(CLERK)的姓名、编号和部门。selectENAME,EMPNO,DEPTNOfromemp1whereJOB='CLERK';3:找出佣金高(comm)于薪金的雇员。select*fromemp1whereCOMM>SALandJOB='CLERK';4:找出佣金高于薪金60%的雇员。select*fromemp1whereCOMM*0.6>SALandJOB='CLERK';5:找出部门10中所有经理和部门20中所有办事员的详细资料。select*fromemp1whereDEPTNO=10andJOB='MANAGER'unionselect*fromemp1whereJOB='SALESMAN';6:找出部门10中所有经理和部门20中所有办事员以及既不是经理又不是办事员但其薪金大于或等于2000的所有雇员的详细资料。select*fromemp1whereDEPTNO=10andJOB='MANAGER'unionselect*fromemp1whereJOB='SALESMAN'unionselect*fromemp1whereJOBin('CLERK')andSAL>=2000;7:找出收取佣金的雇员的不同工作。selectdistinctJOBfromemp1wherejob='CLERK';8:找出不收取佣金或收取佣金低于100的雇员。select*fromemp1whereCOMMisnullornvl(COMM,0)<100;9:按照部门编号显示所有雇员信息。select*fromemp1orderbyDEPTNO;作业要求:将SQL语句复制粘贴在相对应的题目下面。1:找出各月最后一天受雇的所有雇员selectdeptno,enamefromempwherehiredate=last_day(hiredate);2:找出早于12年之前受雇的雇员selectENAME,months_between(sysdate,HIREDATE)/12as年fromempwhereJOB='CLERK'and(months_between(sysdate,HIREDATE)/12)>12;3:显示只有首字母大写的所有雇员的姓名selectUPPER(SUBSTR(ename,1,1))||LOWER(SUBSTR(ename,2,LENGTH(ename)-1))FROMempwhereJOB='CLERK';4:显示正好为15个字符的雇员姓名selectdeptno,enamefromempwherelength(ename)=15andJOB='CLERK';5:显示不带有‘R’的雇员姓名selectenamefromempwhereenamenotlike'%R%'andJOB='CLERK';6:显示所有雇员的姓名的前3个字符selectsubstr(ename,1,3)fromempwhereJOB='CLERK';7:显示所有雇员的姓名,用‘a’替换所有的‘A’selectreplace(ename,'A','a')fromemp;8:显示所有雇员的姓名以及满10年服务年限的日期selectename,hiredate,add_months(hiredate,10*12)fromemp;9:显示雇员的详细资料,按姓名排序select*fromemporderbyename;10:显示雇员姓名,根据其服务年限,将最老的雇员排在最前面selectempno,ename,job,mgr,hiredate,sal,comm,deptno,(sysdate-hiredate)/365fromemporderby(sysdate-hiredate)/365desc;11:显示所有雇员的姓名、工作和薪金,按工作内的工作的降序顺序排序,而工作按薪金排序selectename,job,salfromemporderbyjobdesc,salasc;12:显示所有雇员的姓名和加入公司的年份和月份,按雇员受雇日所在月排序,并将最早年份的项目排在最前面selectename,to_char(hiredate,'YYYY')year1,to_char(hiredate,'MON')month1fromemporderbyyear1asc,month1;13:显示在一个月为30天的情况下所有雇员的日薪金,忽略小数selectround(sal/30,0)asdaypayfromemp;14:找出在(任何年份的)2月份受雇的所有雇员select*fromempwherehiredatelike'%-2月%';15:对于每个雇员,显示其加入公司的天数selectround((sysdate-hiredate))fromemp;16:显示姓名字段的任何位置,包含‘A’的所有雇员的姓名selectenamefromempwhereenamelike'%A%';17:以年、月和日显示所有雇员的服务年限selectename,to_number(to_char(sysdate,'YYYY'))-to_number(to_char(hiredate,'YYYY'))-1,to_number(to_char(sysdate,'mm'))-to_number(to_char(hiredate,'mm'))+10,to_number(to_char(sysdate,'dd'))-to_number(to_char(hiredate,'dd'))+30fromemp;18:列出至少有一个雇员的所有部门selectdeptnofromempgroupbydeptnohavingcount(deptno)>0;19:列出薪金比“SMITH”多的所有雇员SELECTename,sal,deptnoFROMempWHEREsal>(SELECTsalFROMempWHEREename='SMITH');20:列出所有雇员的姓名及其部门名selectENAME,DEPTNOfromempwhereJOB='CLERK';21:列出所有入职日期早于其直接上级的所有雇员SELECTe.enameas职工,m.enameas经理FROMempeleftjoinempmon(e.mgr=m.empno)wheree.hiredate1500;23:列出薪金高于公司平均水平的所有雇员selectename,deptnofromempwheresal>(selectavg(sal)fromemp);24:列出与“SCOTT”从事相同工作的所有雇员selectdeptno,enamefromempwherejob=(selectjobfromempwhereename='SCOTT');25:列出薪金高于在部门30工作的所有雇员的薪金SELECTename,salfromempwheresal>all(selectsalfromempwheredeptno=30);26:列出薪金高于在部门30工作的最高的薪金SELECTename,salfromempwheresal>all(selectmax(sal)fromempwheredeptno=30);27:列出每个部门雇员的数量selectdeptno,count(*)fromempgroupbydeptno;28:列出所有雇员的名称,部门名称和薪金selectENAME,DEPTNO,SALfromempwhereJOB='CLERK';29:列出从事同一种工作但不属于同一部门的这些员工selectjob,deptnofromempgroupbyjob,deptno;30:列出个类别工作的最低工资selectjob,min(sal)fromempgroupbyjob;31:列出各个部门的经理的最低薪金selectDEPTNO,min(sal)fromempwherejob='MANAGER'groupbyDEPTNO;32:列出按计算的字段排序的所有雇员的年薪selectename,(sal+nvl(comm,0))*12asyearpayfromemporderbyyearpaydesc;33:列出所有CLERK的姓名及其部门名称selectENAME,DEPTNOfromepwhereJOB='CLERK';34:列出薪金水平处于前四位的雇员selectsal,enamefromemporderbysaldesc;35:求出所有员工入职了多少年零多少月零多少天selectempno,ename,to_char(floor(to_number((sysdate-hiredate)/365)))||'years'||to_char(ceil(months_between(sysdate,hiredate)-(floor(to_number((sysdate-hiredate)/365)))*12))||'months'fromemp;作业要求:将SQL语句复制粘贴在相对应的题目下面。1:找出各月最后一天受雇的所有雇员select*fromempwherehiredate=last_day(hiredate);2:找出早于12年之前受雇的雇员select*fromempwhereto_number(to_char(sysdate,'yyyy'))-to_number(to_char(hiredate,'yyyy'))>12;3:显示只有首字母大写的所有雇员的姓名SELECTinitcap(ename)FROMemp;SELECTenamefromempwhereename=initcap(ename);4:显示正好为15个字符的雇员姓名selectENAMEfromempwherelength(ENAME)=15;5:显示不带有‘R’的雇员姓名selectENAMEfromempwhereENAMEnotlike'%R%';6:显示所有雇员的姓名的前3个字符selectsubstr(ENAME,0,3)fromemp;7:显示所有雇员的姓名,用‘a’替换所有的‘A’selectreplace(ENAME,'A','a')fromemp;8:显示所有雇员的姓名以及满10年服务年限的日期selectename,add_months(hiredate,120)fromemp;9:显示雇员的详细资料,按姓名排序select*fromemporderbyename;10:显示雇员姓名,根据其服务年限,将最老的雇员排在最前面selectenamefromemporderbyhiredate;11:显示所有雇员的姓名、工作和薪金,按工作内的工作的降序顺序排序,而工作按薪金排序selectename,job,salfromemporderbyjobdesc,saldesc;12:显示所有雇员的姓名和加入公司的年份和月份,按雇员受雇日所在月排序,并将最早年份的项目排在最前面selectename,to_char(hiredate,'yyyy-mm')as"加入年月"fromemporderbyto_char(hiredate,'mm')asc,to_char(hiredate,'yyyy')asc;13:显示在一个月为30天的情况下所有雇员的日薪金,忽略小数selectround(sal/30,0)fromemp;14:找出在(任何年份的)2月份受雇的所有雇员select*fromempwhereto_char(hiredate,'mm')='02';15:对于每个雇员,显示其加入公司的天数selectename,round(sysdate-hiredate,0)"加入公司天数"fromemp;16:显示姓名字段的任何位置,包含‘A’的所有雇员的姓名selectenamefromempwhereenamelike'%A%';17:以年、月和日显示所有雇员的服务年限selectename,hiredate,trunc(months_between(sysdate,hiredate)/12)年,trunc(mod(months_between(sysdate,hiredate),12))月,trunc(sysdate-add_months(hiredate,months_between(sysdate,hiredate)))日fromemp;18:列出至少有一个雇员的所有部门selectdeptno,count(0)fromempgroupbydeptnohavingcount(0)>=119:列出薪金比“SMITH”多的所有雇员selectenamefromempwheresal>(selectsalfromempwhereename='SMITH');selecte2.*fromempe1,empe2wheree1.ename='SMITH'ande2.sal>e1.sal;20:列出所有雇员的姓名及其部门名selecte.ename,d.dnamefromempe,deptdwheree.deptno=d.deptno;selecte.ename,d.dnamefromempejoindeptdone.deptno=d.deptno;21:列出所有入职日期早于其直接上级的所有雇员select*fromempe1wherehiredate<(selecthiredatefromempe2wheree2.empno=e1.mgr);22:列出各种类别的最低薪金,并使薪金大于1500selectjob,min(sal)fromempgroupbyjobhavingmin(sal)>1500;23:列出薪金高于公司平均水平的所有雇员select*fromempwheresal>(selectavg(sal)fromemp);24:列出与“SCOTT”从事相同工作的所有雇员select*fromempwherejob=(selectjobfromempwhereename='SCOTT');25:列出薪金高于在部门30工作的所有雇员的薪金selectename,salfromempwheresal>(selectmax(sal)fromempwheredeptno=30);selectename,salfromempwheresal>all(selectsalfromempwheredeptno=30);26:列出薪金高于在部门30工作的最高的薪金selectename,salfromempwheresal>(selectmax(sal)fromempwheredeptno=30);27:列出每个部门雇员的数量selectd.*,(selectcount(deptno)fromempewheree.deptno=d.deptno)"雇员人数"fromdeptd;28:列出所有雇员的名称,部门名称和薪金selectename,(selectdnamefromdeptdwhered.deptno=e.deptno)"部门名称",salfromempe;selecte.ename,d.dname,salfromempe,deptdwheree.deptno=d.deptno;29:列出从事同一种工作但不属于同一部门的这些员工selectdistincta.enamefromempa,empbwhere(a.job=b.job)and(a.deptno!=b.deptno);30:列出个类别工作的最低工资selectjob,min(sal)fromempgroupbyjob;31:列出各个部门的经理的最低薪金selectmin(sal)fromempwherejob='MANAGER';32:列出按计算的字段排序的所有雇员的年薪selectename,(sal+nvl(comm,0))*12as雇员的年薪fromemporderby雇员的年薪;33:列出所有CLERK的姓名及其部门名称selecta.ename,b.dnamefromempa,deptbwherea.job='CLERK'anda.deptno=b.deptno;selecte.ename,d.dnamefromempejoindeptdone.deptno=d.deptnowheree.job='CLERK'34:列出薪金水平处于前四位的雇员select*from(selecte.*,rownumrfrom(select*fromemporderbysal)ewhererownum<=11)twheret.r>=10;35:求出每个员工入职多少年零多少月零多少日selectename,hiredate,trunc(months_between(sysdate,hiredate)/12)年,trunc(mod(months_between(sysdate,hiredate),12))月,trunc(sysdate-add_months(hiredate,months_between(sysdate,hiredate)))天fromemp;
本文档为【Oracle第二章习题及答案】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
个人认证用户
ice
我是一线教师,教学生涯也有数十年 教学经验丰厚,原创文档也有很多 想和大家分享
格式:doc
大小:165KB
软件:Word
页数:0
分类:
上传时间:2021-10-15
浏览量:6