2021-07-09

数据库

1.复杂查询
  • 多对一,将两张表通过join进行关联,其中的n表是通过查询语句查出,然后

    selct  from emp e join
    () n 
    on n.depno = e.depno
    
  • 使用聚合函数:avg、sum、min、max,count,有 “表单位” 和 “组单位” 。如果是 表单位 的话 ,不管使用哪一个聚合函数,都只查询一条数据。如果是 组单位 ,则会根据组的多少就查询多少条数据。

  • 先查询,后分组

    先把表中的所有职位是经理的数据行查询出来,得到一张关于所有部门经理相关人员信息的表,再以 “部门” 为单位 对此表进行分组。

    select  deptno ,count(1)
    from  emp
    where job = 'MANAGER'
    GROUP BY deptno
    

 SELECT i.*,n1,n2,n3
    FROM `app_info` i
    JOIN 
    (
      SELECT i.`id` iid,`categoryName` n1
      FROM  `app_category`  c
      JOIN  `app_info` i
      ON c.`id` = i.`categoryLevel1`
      ) c1
     ON  c1.iid = i.id
    JOIN
     (
      SELECT i.`id` iid,`categoryName` n2
      FROM  `app_category`  c
      JOIN  `app_info` i
      ON c.`id` = i.`categoryLevel2`
      ) c2
      ON c2.iid = i.id
     JOIN
      ( 
      SELECT i.`id` iid,`categoryName` n3
      FROM  `app_category`  c
      JOIN  `app_info` i
      ON c.`id` = i.`categoryLevel3`
      ) c3
      ON c3.iid = i.id
  • join … on ,可以将需要的数据查询出来,然后自己将其声明成一张新表,可以使用join 新表 on 获取行数据条件,然后就可以查询出一张自己所需要数据的一张表了!!!虽然查询所需数据不在同一张表,当时表和表之间有通过主外键进行关联,只要有关联,我们就可以查出我们所需要主键所在表的数据,然后和外键所在的表组成一张新表。这样就可以获得我们在项目中所想要的数据了!

  • desc : 降序 asc :升序

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

UPYOLo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值