Oracle入门SQL练习(一)
以下内容以scott用户下Oracle自带实例orcl库中四张表进行查询,作为Oracle入门SQL基础练习笔记,不忘初心,加油!--1).查询一个用户下所有的表
SELECT * FROM tab;
--2).查询一张表的结构(命令行):DESC 表名称
DESC dept;
--简单查询语法结构:SELECT * | 列名称 [别名],列名称 [别名],... 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,sal12 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 | 列名称 [别名],列名称 [别名],... FROM 表名称 [别名] ;
--关系运算符
--9).查询出所有基本工资高于2000的雇员信息
SELECTFROM 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 sal2000 OR job = 'CLERK';
--15.查询工资小于2000的雇员信息
SELECT FROM emp WHERE sal < 2000;
SELECTFROM emp WHERE NOT sal >= 2000;
--范围查询
--16.查询出工资范围在1500~2000之间的雇员信息(包含1500,2000)
SELECT FROM emp WHERE sal >= 1500 AND salsal0.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
页:
[1]