Oracle

1切换到 oracle的 hr用户下面练习

 

1. 查询工资大于12000的员工姓名和工资

select first_name,last_name,salary from employees where salary>12000;

2. 查询员工号为176的员工的姓名和部门号

select first_name,last_name,department_id from employees where employee_id='176';

3. 选择工资不在500012000的员工的姓名和工资

select first_name,last_name,salary from employees where salary not between 5000 and 12000;

4. 选择雇用时间在1998-02-011998-05-01之间的员工姓名,job_id和雇用时间

select first_name,last_name,job_id,hire_date from employees where hire_date between

'01-2-1998'and '01-5-1998';

5. 选择在2050号部门工作的员工姓名和部门号

select first_name,last_name,department_id from employees where department_id in('20','50');

6. 选择在1994年雇用的员工的姓名和雇用时间

select first_name,last_name,hire_date from employees where hire_date like '%94';

7. 选择公司中没有管理者的员工姓名及job_id

select first_name,last_name,job_id from employees where manager_id is null;

8. 选择公司中有奖金的员工姓名,工资和奖金级别

select first_name,last_name,salary,commission_pct from employees where commission_pct is not null;

9. 选择员工姓名的第三个字母是a的员工姓名

select first_name,last_name from employees where first_name like'__a%';

select first_name,last_name from employees where last_name like'__a%';

10. 选择姓名中有字母ae的员工姓名

11. 显示系统时间

select sysdate from dual;

12. 查询员工号,姓名,工资,以及工资提高百分之20%后的结果(new salary

select employee_id,first_name,last_name,salary,salary*(1+0.2) as "new salary" from employees;

13. 将员工的姓名按首字母排序,并写出姓名的长度(length

select first_name,last_name,months_between(sysdate,hire_date) as "月份" from employees;

14. 查询各员工的姓名,并显示出各员工在公司工作的月份数

select first_name,last_name,months_between(sysdate,hire_date) as "月份" from employees;

15. 查询员工的姓名,以及在公司工作的月份数(worked_month),并按月份数降序排列

select first_name,last_name,months_between(sysdate,hire_date) as "月份" from employees  order by months_between(sysdate,hire_date) desc;

 

posted @ 2013-04-03 19:55  xinyuyuanm  阅读(156)  评论(0编辑  收藏  举报