以下内容以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,sal12 income FROM emp;
--7).查询每个雇员的编号、姓名、基本年薪(每年15薪,每月200元饭补、100元车补、100元话费,5个月的其他补贴200) SELECT empno,ename,(sal*15+(200+100+100)12+2005) 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;