Oracle的sql語句模擬試題及答案

1、選擇部門30中的僱員

Oracle的sql語句模擬試題及答案

select * from emp where deptno=30;

2、列出所有辦事員的姓名、編號和部門

select ename,empno,dname from emp e inner join dept d on no = no where job=upper('clerk’);

3、找出佣金高於薪金的僱員

select * from emp where comm>sal;

4、找出佣金高於薪金60%的僱員

select * from emp where comm>sal*0.6

5、找出部門10中所有經理和部門20中的所有辦事員的詳細資料

select * from emp where (deptno=10 and job=upper('manager')) or (deptno=20 and job=upper('clerk '));

6、找出部門10中所有經理、部門20中所有辦事員,既不是經理又不是辦事員但其薪金>=2000的所有僱員的詳細資料

select * from emp where (deptno=10 and job=upper('manager')) or (deptno=20 and job=upper('clerk ')) or (job<>upper(‘manager’) and job<>upper(‘clerk’) and sal>=2000)

7、找出收取佣金的僱員的不同工作

select distinct job from emp where comm>0;

8、找出不收取佣金或收取的佣金低於100的僱員

select * from emp where nvl(comm,0)<100;

9、找出各月最後一天受僱的所有僱員

select * from emp where hiredate= last_day(hiredate);

10、找出早於25年之前受僱的僱員

select * from emp where months_between(sysdate,hiredate)/12>25;

select * from emp where hiredate

11、顯示只有首字母大寫的所有僱員的姓名

select ename from emp where ename=initcap(ename);

12、顯示正好爲6個字符的僱員姓名

select ename from emp where length(ename)=6

13、顯示不帶有'R'的僱員姓名

Select ename from emp where ename not like ‘%R%’;

Select ename from emp where instr(ename,’R’)=0;

14、顯示所有僱員的姓名的前三個字符

select substr(ename,1,3) from emp

15、顯示所有僱員的姓名,用a替換所有'A'

Select replace(ename,’A’,’a’) from emp

16、顯示所有僱員的姓名以及滿10年服務年限的日期

Select ename,add_months(hiredate,12*10) ‘服務年限的日期’ from emp

17、顯示僱員的詳細資料,按姓名排序

Select * from emp order by ename

18、顯示僱員姓名,根據其服務年限,將最老的僱員排在最前面

Select ename from emp order by hiredate

19、顯示所有僱員的姓名、工作和薪金,按工作的降序順序排序,而工作相同時按薪金升序

Select ename,job,sal from emp order by job desc ,sal asc

20、顯示所有僱員的姓名和加入公司的年份和月份,按僱員受僱日所在月排序,將最早年份的項目排在最前面

select ename,to_char(hiredate,'yyyy'),to_char(hiredate,'mm') from emp order by hiredate asc

21、顯示在一個月爲30天的情況下所有僱員的日薪金

select ename,sal/30 from emp;

22、找出在(任何年份的)2月受聘的所有僱員

select * from emp where to_char(hiredate,'mm')='02';

23、對於每個僱員,顯示其加入公司的天數

select ename,sysdate-hiredate from emp

24、顯示姓名字段的任何位置,包含 "A" 的'所有僱員的姓名

select ename from emp where ename like '%A%';

select ename from emp where instr(ename,’A’,1)>0;

25、以年、月和日顯示所有僱員的服務年限

Select months_between(sysdate,hiredate)/12 as “年”, months_between(sysdate,hiredate) as “月”, sysdate-hiredate as “日” from emp