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两个条件也是可以的,只是效率低了一点,毕竟连接的表要更大一些

相关推荐
秦歌6666 分钟前
Agent Skills详解
服务器·前端·数据库
Mahir089 分钟前
Redis 分布式锁与 Redisson 深度解析:从原生实现到工业级解决方案
数据库·redis·分布式·缓存·面试
杨云龙UP10 分钟前
MySQL主库高峰期备份引发504故障:从库手动切换接管 + 主从恢复同步 + Docker版DB2重启实战_2026-05-17
linux·运维·数据库·mysql·docker·容器·centos
暖阳之下13 分钟前
学习周报四十五
学习
倔强的石头_13 分钟前
彻底告别Row-By-Row:标量子查询外连接改写与向量化引擎深潜
数据库
2301_8092445314 分钟前
如何解决宝塔面板磁盘空间占满问题_使用磁盘清理工具清理
jvm·数据库·python
sealaugh3215 分钟前
react native(学习笔记第五课) 英语打卡微应用(4)- frontend的列表展示
笔记·学习·react native
六月雨滴18 分钟前
Oracle 数据库网络安全
数据库·安全·dba
En^_^Joy20 分钟前
Django模型:数据库操作全指南
数据库·django·sqlite
六月雨滴22 分钟前
Oracle 数据库网络安全之加密配置
数据库·web安全·oracle