Oracle入门SQL练习(一)

以下内容以scott用户下Oracle自带实例orcl库中四张表进行查询,作为Oracle入门SQL基础练习笔记,不忘初心,加油!

--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,(sal15+(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 > sal0.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;

猜你喜欢

转载自blog.51cto.com/13003060/2137380