• MySQL之单表查询练习


    一、emp表

    二、练习

    1. 查询出部门编号为30的所有员工
    2. 所有销售员的姓名、编号和部门编号。
    3. 找出奖金高于工资的员工。
    4. 找出奖金高于工资60%的员工。
    5. 找出部门编号为10中所有经理,和部门编号为20中所有销售员的详细资料。

    6. 找出部门编号为10中所有经理,部门编号为20中所有销售员,还有即不是经理又不是销售员但其工资大或等于20000的所有员工详细资料。

    7. 无奖金或奖金低于1000的员工。
    8. 查询名字由三个字组成的员工。
    9.查询2000年入职的员工。
    10. 查询所有员工详细信息,用编号升序排序
    11. 查询所有员工详细信息,用工资降序排序,如果工资相同使用入职日期升序排序

    三、练习题解

    /*

    */

    /*1. 查询出部门编号为30的所有员工*/
    SELECT *
    FROM emp
    WHERE deptno=30;

    /*2. 查询所有销售员的姓名、编号和部门编号。*/
    SELECT ename, empno, deptno
    FROM emp
    WHERE job='销售员';

    /*3. 找出奖金高于工资的员工。*/
    SELECT *
    FROM emp
    WHERE comm > sal

    /*4. 找出奖金高于工资60%的员工。*/
    SELECT *
    FROM emp
    WHERE comm > sal*0.6;

    /*5. 找出部门编号为10中所有经理,和部门编号为20中所有销售员的详细资料。*/
    SELECT *
    FROM emp
    WHERE (deptno=10 AND job='经理') OR (deptno=20 AND job='销售员')

    /*6. 找出部门编号为10中所有经理,部门编号为20中所有销售员,还有即不是经理又不是销售员但其工资大或等于20000的所有员工详细资料。*/
    SELECT *
    FROM emp
    WHERE (deptno=10 AND job='经理') OR (deptno=20 AND job='销售员') OR (job NOT IN ('经理', '销售员') AND sal >= 20000)

    /*7. 无奖金或奖金低于1000的员工。*/
    SELECT *
    FROM emp
    WHERE comm IS NULL OR comm < 1000

    /*8. 查询名字由三个字组成的员工。*/
    SELECT *
    FROM emp
    WHERE ename LIKE '___'

    /*9.查询2000年入职的员工。*/
    SELECT *
    FROM emp
    WHERE hiredate LIKE '2000-%'

    /*10. 查询所有员工详细信息,用编号升序排序*/
    SELECT * 
    FROM emp
    ORDER BY empno

    /*11. 查询所有员工详细信息,用工资降序排序,如果工资相同使用入职日期升序排序*/
    SELECT *
    FROM emp
    ORDER BY sal DESC, hiredate ASC

  • 相关阅读:
    后海日记(6)
    后海日记(6)
    后海日记(5)
    后海日记(5)
    TCP 连接的握手信息详解
    TCP 连接的握手信息详解
    java枚举类型的优势在哪里?--一个实例
    java枚举类型的优势在哪里?--一个实例
    网络基础之网络协议篇
    mysql之innodb引擎的共享表空间和独立表空间
  • 原文地址:https://www.cnblogs.com/gdwkong/p/7487248.html
Copyright © 2020-2023  润新知