【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 详解
相关推荐
web182854825126 分钟前
MySQL 篇 - Java 连接 MySQL 数据库并实现数据交互
java·数据库·mysql
mqwguardain41 分钟前
Python连接不同数据库的总结
开发语言·数据库·python
林涧泣1 小时前
【Uniapp-Vue3】创建DB schema数据表结构
数据库·uni-app
GIS小小研究僧2 小时前
PostGIS:使用shp2pgsql、pgsql2shp、OGR2OGR函数进行数据导入、导出
数据库·postgresql·postgis
测试界清流3 小时前
自动化测试、压力测试、持续集成
数据库·git
荔枝味啊~3 小时前
杭州某小厂面试
java·网络·数据库·tcp/ip·面试
Gauss松鼠会3 小时前
数据库高安全—审计追踪:传统审计&统一审计
网络·数据库·安全·oracle·gaussdb
egekm_sefg3 小时前
【玩转全栈】----Django模板的继承
数据库·django·sqlite
喝醉酒的小白4 小时前
达梦数据库从单主模式转换为主备模式
数据库