h0945466 发表于 2018-9-21 11:14:00

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]
查看完整版本: Oracle入门SQL练习(一)