MySQL数据库学习

1.group by分组问题

一般来说,group by的分组要配合上聚合函数,如count(),sum(),avg(),max(),min()

select city,count(city) as city_count from Country

group by city;

这样就建立一个新表,第一列是城市名,第二列是城市出现的次数

有时我们需要筛选,先筛选再分组使用where

select city,count(city) as city_count from Country

where area >=3000000

group by city;

这样先筛选面积大于3000000的城市,再统计出现次数。

有时我们需要后筛选,我们要列出城市出现次数大于5次的城市及次数,那么我们使用having

select city,count(city) as city_count from Country

where area >=3000000

group by city

having city_count >5;

2.连接问题join

连接的问题用left join比较多,用于两个表有相同的主键用on关键字按条件连接。值得注意的是,默认的连接方式是inner,有时我们需要outer外连接就用left outer join.

还有一类就是cross join和自己交叉连接,比如力扣197.上升的温度,让你列出当日温度比前一天温度高的条目。

select id from table as a

cross join table as b

on datediff(a.date,b.date)=1

where a.temperature>b.temperature;

这个语句将原表和新表分别命名为a和b,通过日期相差一天的条件进行连接,最后限制条件温度较前一天高。

值得注意的是,不用on连接而是用where and两个条件也是可以的,只是效率低了一点,毕竟连接的表要更大一些

相关推荐
lwf0061643 小时前
导数学习日记
学习·算法·机器学习
qeen873 小时前
【编程日记】现阶段总结
学习
sunshine8854 小时前
财务RPA的深水区应用:超越自动化,迈向智能决策支持
数据库
efir OONA4 小时前
MySQL数据库误删恢复_mysql 数据 误删
数据库·mysql·adb
zhangchaoxies5 小时前
如何在 Go 中安全复制接口指针所指向的值
jvm·数据库·python
陈陈CHENCHEN5 小时前
【数据库】MySQL 8.0.40 至 8.0.44 RPM 方式升级指南
数据库·mysql
-Marks-6 小时前
【C++编程】STL简介 --- (是什么 | 版本发展历程 | 六大组件 | 重要性缺陷以及如何学习)
开发语言·c++·学习·stl·stl版本
m0_734949796 小时前
怎么利用Navicat进行调整备份文件压缩等级_详细配置与操作步骤
jvm·数据库·python
T.i.s6 小时前
番外续2-MIT-BIH Arrhythmia Database
数据库
有味道的男人6 小时前
AI 效率翻倍:对接 1688 拍立淘接口,商品全量信息一键抓取
数据库