根据Oracle数据库scott模式下的emp表和dept表.doc
根据Oracle数据库scott模式下的emp表和dept表
题目要求:根据Oracle数据库scott模式下的emp表和dept表,完成下列操作。
查询20号部门的所有员工信息。
select*fromempwheredeptno=20;
查询所有工种为CLERK的员工的工号、员工名和部门名。
selectempno,ename,deptnofromempwherejoblikeCLERK;
查询奖金(COMM)高于工资(SAL)的员工信息。
select*fromempwherecommsal;
查询奖金高于工资的20%的员工信息。
select*fromempwherecomm(sal*0.2);
查询10号部门中工种为MANAGER和20号部门中工种为CLERK的员工的信息。
select*fromemp
where(deptno=10andjoblikeMANAGER)or(deptno=20andjoblikeCLERK);
查询所有工种不是MANAGER和CLERK,且工资大于或等于2000的员工的详细信息。
select*fromemp
wherejobnotin(MANAGER,CLERK)andsal=2000;
查询有奖金的员工的不同工种。
selectdistinctjobfromempwherecommisnotnull;
查询所有员工工资和奖金的和。
selectename,(sal+nvl(comm,0))salcommfromemp;
查询没有奖金或奖金低于100的员工信息。
select*fromempwhere(commisnullorcomm100);
查询各月倒数第2天入职的员工信息。
select*fromempwherehiredatein(select(last_day(hiredate)-1)fromemp);
查询员工工龄大于或等于10年的员工信息。
select*fromempwhere(sysdate-hiredate)/365=10;
查询员工信息,要求以首字母大写的方式显示所有员工的姓名。
selectupper(substr(ename,1,1))||lower(substr(ename,2,length(ename)-1))fromemp;
查询员工名正好为6个字符的员工的信息。
select*fromempwherelength(ename)=6;
查询员工名字中不包含字母“S”员工。
select*fromempwhereenamenotin(selectenamefromempwhereenamelike%S%);
select*fromempwhereenamenotlike‘%S%’;
查询员工姓名的第2个字母为“M”的员工信息。
select*fromempwhereenamelike_M%;
查询所有员工姓名的前3个字符。
selectsubstr(ename,1,3)fromemp;
查询所有员工的姓名,如果包含字母“s”,则用“S”替换。
selectreplace(ename,s,S)fromemp;
查询员工的姓名和入职日期,并按入职日期从先到后进行排列。
selectename,hiredatefromemporderbyhiredateasc;
显示所有的姓名、工种、工资和奖金,按工种降序排列,若工种相同则按工资升序排列。
selectename,job,sal,commfromemporderbyjobdesc,salasc;
显示所有员工的姓名、入职的年份和月份,若入职日期所在的月份排序,若月份相同则按入职的年份排序。
selectename,to_char(hiredate,yyyy)||-||to_char(hiredate,mm)fromemporderbyto_char(hiredate,mm),to_char(hiredate,yyyy);
查询在2月份入职的所有员工信息。
select*fromempwhereto_char(hiredate,mm)=2;
查询所有员工入职以来的工作期限,用“**年**月**日”的形式表示。
selectename,floor((sysdate-hiredate)/365)||年||floor(mod((sysdate-