Oracle入门SQL练习(一)

以下内容以scott用户下Oracle自带实例orcl库中四张表进行查询,此部分为简单查询,作为练习笔记进行记录


--1).查询一个用户下所有的表
SELECT * FROM tab;


--2).查询一张表的结构(命令行):DESC 表名称
DESC dept;


--简单查询语法结构:SELECT [DISTINCT] * | 列名称 [别名],列名称 [别名],... FROM 表名称 [别名];


--3).查询emp表中的全部记录
SELECT * FROM emp;


--4).查询每个雇员的编号、姓名、职位、工资
SELECT empno,ename,job,sal FROM emp;


--5).查询所有的职位信息,使用DISTINCT消去重复
SELECT DISTINCT job FROM emp;


--6).查询每个雇员的编号、姓名、职位、基本年薪(月薪*12),使用别名
SELECT empno,ename,job,sal*12 income FROM emp;


--7).查询每个雇员的编号、姓名、基本年薪(每年15薪,每月200元饭补、100元车补、100元话费,5个月的其他补贴200)
SELECT empno,ename,(sal*15+(200+100+100)*12+200*5) income FROM emp;


--8).常量+连接,查询显示结构:雇员XXX的基本工资是XXX
SELECT '雇员' || ename || '的基本工资是' || sal info FROM emp;


--限定查询语法结构:SELECT [DISTINCT] * | 列名称 [别名],列名称 [别名],... FROM 表名称 [别名] [WHERE 过滤条件(s)];
--关系运算符
--9).查询出所有基本工资高于2000的雇员信息
SELECT * FROM emp WHERE sal > 2000;


--10).查询SMITH的完整信息
SELECT * FROM emp WHERE ename = 'SMITH';


--11.查询工资为5000的员工信息
SELECT * FROM emp WHERE sal = 5000;


--12.查询不是销售人员的编号、姓名、职位
SELECT empno,ename,job FROM emp WHERE job != 'SALESMAN';
SELECT empno,ename,job FROM emp WHERE job <> 'SALESMAN';


--逻辑运算符


--13.查询出工资范围在1500~3000之间的雇员信息
SELECT * FROM emp WHERE sal >= 1500 AND sal <= 3000;


--14.查询工资大于2000或者职位是办事员的雇员信息
SELECT * FROM emp WHERE sal > 2000 OR job = 'CLERK';


--15.查询工资小于2000的雇员信息
SELECT * FROM emp WHERE sal < 2000;
SELECT * FROM emp WHERE NOT sal >= 2000;


--范围查询


--16.查询出工资范围在1500~2000之间的雇员信息(包含1500,2000)
SELECT * FROM emp WHERE sal >= 1500 AND sal <= 2000;
SELECT * FROM emp WHERE sal BETWEEN 1500 AND 2000;


--17.查询所有在1981年雇佣的雇员信息
SELECT * FROM emp WHERE hiredate BETWEEN '01-1月 -1981' AND '31-12月 -1981';


--空判断 注意空和0


--18.查询所有领取佣金的雇员信息(佣金不为null)
SELECT * FROM emp WHERE NOT comm IS NULL;
SELECT * FROM emp WHERE comm IS NOT NULL;


--IN操作符


--19.要求查询雇员编号为7369、7566、7788、9999的雇员信息
SELECT * FROM emp WHERE empno IN (7369,7566,7788,9999);


--模糊查询


--20.查询姓名是以A开头的雇员信息
SELECT * FROM emp WHERE ename LIKE 'A%';


--21.查询姓名的第二字字母是A的雇员信息
SELECT * FROM emp WHERE ename LIKE '_A%'


--22.查询姓名中包含字母是A的雇员信息
SELECT * FROM emp WHERE ename LIKE '%A%'


--查询排序


--23.查询所有雇员信息,要求按照工资由高到低排序(降序)
SELECT * FROM emp ORDER BY sal DESC;


--24.查询所有销售人员的信息,要求按照入职年限由早到晚排序(升序)
SELECT * FROM emp WHERE job='SALESMAN' ORDER BY hiredate ASC;


--25.要求按照工资由高到低排序,若工资相同,则按入职时间由早到晚排序
SELECT * FROM emp ORDER BY sal DESC, hiredate ASC;


--26.查询每个雇员的编号,姓名,年薪,按照年薪升序
SELECT empno,ename,sal*12 income FROM emp ORDER BY income;


--基础查询练习


--1.查询部门30中的所有员工信息
SELECT * FROM emp WHERE deptno=30;


--2.列出所有办事员(CLERK)的编号、姓名和部门编号
SELECT empno,ename,deptno FROM emp WHERE job='CLERK';


--3.找出佣金高于薪金60%的员工
SELECT * FROM emp WHERE comm > sal*0.6;


--4.找出部门10中所有经理(MANAGER)和部门20中所有办事员(CLERK)的全部信息
SELECT * FROM emp WHERE (deptno=10 AND job='MANAGER') OR (deptno=20 AND job='CLERK');


--5.找出部门10中所有经理(MANAGER),部门20中所有办事员(CLERK),既不是经理又不是办事员但其薪金大于等于2000的雇员信息
SELECT *
  FROM EMP
 WHERE (DEPTNO = 10 AND JOB = 'MANAGER')
    OR (DEPTNO = 20 AND JOB = 'CLERK')
    OR (JOB NOT IN ('MANAGER', 'CLERK') AND SAL >= 2000);


--6.找出收取佣金的员工的工作
SELECT DISTINCT job FROM emp WHERE comm IS NOT NULL;


--7.找出不收取佣金或者收取佣金小于100的员工
SELECT * FROM emp WHERE comm IS NULL OR comm<100;


--8.显示姓名中不带有‘R’的员工信息
SELECT * FROM emp WHERE ename NOT LIKE '%R%';


--9.显示姓名中任何位置包含字母‘A'的员工信息,显示的结果按照基本工资由高到低排序,
--  若工资相同,则按照雇佣年限由早到晚排序,若年限相同,则按职位排序
SELECT * FROM emp WHERE ename LIKE '%A%' ORDER BY sal DESC,hiredate,job;





  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值