• 多表查询汇总


    select *
    from emp, dept, (select * from emp)
    where
    group by
    having
    order by
    limit

    多表查询
      1. 分类:
        * 合并结果集(了解)
        * 连接查询
        * 子查询

    合并结果集
      * 要求被合并的表中,列的类型和列数相同
      * UNION,去除重复行
      * UNION ALL,不去除重复行

    SELECT * FROM cd
    UNION ALL
    SELECT * FROM ab;

    连接查询
      1. 分类
        * 内连接
        * 外连接
          > 左外连接
          > 右外连接
          > 全外连接(MySQL不支持)
        * 自然连接(属于一种简化方式)

      2. 内连接
        * 方言:SELECT * FROM 表1 别名1, 表2 别名2 WHERE 别名1.xx=别名2.xx
        * 标准:SELECT * FROM 表1 别名1 INNER JOIN 表2 别名2 ON 别名1.xx=别名2.xx
        * 自然:SELECT * FROM 表1 别名1 NATURAL JOIN 表2 别名2
        * 内连接查询出的所有记录都满足条件。
     
      3. 外连接
        * 左外:SELECT * FROM 表1 别名1 LEFT OUTER JOIN 表2 别名2 ON 别名1.xx=别名2.xx
          > 左表记录无论是否满足条件都会查询出来,而右表只有满足条件才能出来。左表中不满足条件的记录,右表部分都为NULL
        * 左外自然:SELECT * FROM 表1 别名1 NATURAL LEFT OUTER JOIN 表2 别名2
        * 右外:SELECT * FROM 表1 别名1 RIGHT OUTER JOIN 表2 别名2 ON 别名1.xx=别名2.xx
          > 右表记录无论是否满足条件都会查询出来,而左表只有满足条件才能出来。右表不满足条件的记录,其左表部分都为NULL
        * 右外自然:SELECT * FROM 表1 别名1 NATURAL RIGHT OUTER JOIN 表2 别名2 ON 别名1.xx=别名2.xx
        * 全链接:可以使用UNION来完成全链接

    子查询
      :查询中有查询(查看select关键字的个数!)
      1. 出现的位置:
        * where后作为条件存在
        * from后作为表存在(多行多列)

      2. 条件
        * (***)单行单列:SELECT * FROM 表1 别名1 WHERE 列1 [=、>、<、>=、<=、!=] (SELECT 列 FROM 表2 别名2 WHERE 条件)
        * (**)多行单列:SELECT * FROM 表1 别名1 WHERE 列1 [IN, ALL, ANY] (SELECT 列 FROM 表2 别名2 WHERE 条件)
        * (*)单行多列:SELECT * FROM 表1 别名1 WHERE (列1,列2) IN (SELECT 列1, 列2 FROM 表2 别名2 WHERE 条件)
        * (***)多行多列:SELECT * FROM 表1 别名1 , (SELECT ....) 别名2 WHERE 条件

    ====================================================

    笛卡尔积
    {a, b, c} {1,2}
    {a1, a2, b1, b2, c1, c2}


    ====================================================

    1. 查出至少有一个员工的部门。显示部门编号、部门名称、部门位置、部门人数。select d.deptno,d.dname,d.loc ,e.c from dept d inner join(select deptno,count(*) c from emp group by deptno) e where d.deptno=e.deptno;
    3. 列出所有员工的姓名及其直接上级的姓名。

    select e.ename en,m.ename mn  from emp e,emp m where m.empno=e.mgr;

    4. 列出受雇日期早于直接上级的所有员工的编号、姓名、部门名称。

    select e.ename en,m.ename mn ,e.hiredate employee,m.hiredate loader,d.dname from emp e,emp m ,dept d where m.empno=e.mgr and m.hiredate>e.hiredate and e.deptno=d.deptno;




    5. 列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。
    select d.dname,e.*from dept d left outer join emp e on d.deptno=e.deptno;



    7. 列出最低薪金大于15000的各种工作及从事此工作的员工人数。
    select job ,count(*)from emp group by job having min(sal)>15000;


    8. 列出在销售部工作的员工的姓名,假定不知道销售部的部门编号。

    select e.ename
    from emp e ,dept d
    where d.deptno=e.deptno and d.dname='销售部';






    9. 列出薪金高于公司平均薪金的所有员工信息,所在部门名称,上级领导,工资等级。

    select d.dname,e.*,m.ename,s.grade
    from emp e left outer join dept d  on e.deptno=d.deptno left outer join emp m on e.mgr=m.empno left outer join salgrade s on e.sal between s.losal and s.hisal where e.sal>(select avg(sal)from emp);



    10.列出与庞统从事相同工作的所有员工及部门名称。

    select d.dname,e.ename,e.job
    from dept d,emp e
    where job=(select job from emp where ename='庞统')and d.deptno=e.deptno;


    11.列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金、部门名称。

    select e.ename,e.sal,d.dname
    from emp e,dept d
    where e.deptno=d.deptno and e.sal>(select max(sal) from emp where deptno=30);






    13.查出年份、利润、年度增长比








    2. 列出薪金比关羽高的所有员工。
    select*from emp where sal>(select sal from emp where ename='关羽');






    6. 列出所有文员的姓名及其部门名称,部门的人数。
    select e.ename,d.dname,g.c from emp e, dept d inner join (select deptno,count(*) c from emp group by deptno) g where e.job='文员' and e.deptno=d.deptno and g.deptno=e.deptno;




    12.列出每个部门的员工数量、平均工资。

    select deptno, count(*),avg(sal)from emp group by deptno;



















  • 相关阅读:
    LinqPad 1.31 提供下载
    LINQ to SQL更新数据库操作
    电脑开机进入桌面很慢的解决办法
    VS2008的Linq更新数据就那么费劲
    将图片进行base64编码,并将接受编码后的图片转换为实际图片
    C# 2.0 之 static class
    测试杀毒软件的性能代码
    VS2008 Ajax Toolkit 控件(修正后转载)
    C#发送邮件程序 及测试邮件服务器
    asp.net中的<%%>形式的详细用法实例讲解
  • 原文地址:https://www.cnblogs.com/pai-da-xing/p/8065754.html
Copyright © 2020-2023  润新知