【SQL】585. 2016年的投资 (group by 执行图解)

前述

知识点学习:看一遍就理解:group by 详解 ,图解讲解细致,推荐学习。

题目描述

leetcode题目:585. 2016年的投资


  1. 定位pid:符合两个条件的。直接用条件筛选即可。指定字段in, not in,再结合group by having等。
  2. 再加和,注意小数点后保留两位 => ROUND()函数

写法一

sql 复制代码
select round(sum(A.tiv_2016), 2) as tiv_2016
from Insurance A
where A.tiv_2015 in (
    select tiv_2015
    from Insurance
    group by tiv_2015
    having count(*) > 1
) 
and (lat, lon) in (
    select lat, lon
    from Insurance
    group by lat, lon
    having count(*) = 1
)

写法二

不同点:官方题解中用了concat()函数,不用也行

sql 复制代码
select round(sum(A.tiv_2016), 2) as tiv_2016
from Insurance A
where A.tiv_2015 in (
    select tiv_2015 
    from Insurance
    group by tiv_2015
    having count(*) > 1
    )
and concat(lat, lon) in(
    select concat(lat, lon)
    from Insurance
    group by lat, lon 
    having count(*) = 1
)

记录自己思维错误点:

  1. 要做筛选,从表中挑选出需要的数据,而不要总想着删除表中多余行。(一开始想的是,如何把两个重复经纬度的去掉? )
  2. 注意:where子句还处于"确定"结果集的过程中,因而不能使用聚集函数。用having过滤即可。
  3. group by 细节学习:看一遍就理解:group by 详解
相关推荐
hh随便起个名37 分钟前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
JIngJaneIL2 小时前
基于springboot + vue古城景区管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
微学AI2 小时前
复杂时序场景的突围:金仓数据库是凭借什么超越InfluxDB?
数据库
廋到被风吹走3 小时前
【数据库】【Redis】定位、优势、场景与持久化机制解析
数据库·redis·缓存
LYFlied3 小时前
【每日算法】LeetCode 17. 电话号码的字母组合
前端·算法·leetcode·面试·职场和发展
有想法的py工程师4 小时前
PostgreSQL + Debezium CDC 踩坑总结
数据库·postgresql
Nandeska4 小时前
2、数据库的索引与底层数据结构
数据结构·数据库
小卒过河01044 小时前
使用apache nifi 从数据库文件表路径拉取远程文件至远程服务器目的地址
运维·服务器·数据库
过期动态4 小时前
JDBC高级篇:优化、封装与事务全流程指南
android·java·开发语言·数据库·python·mysql
Mr.朱鹏4 小时前
SQL深度分页问题案例实战
java·数据库·spring boot·sql·spring·spring cloud·kafka