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

相关推荐
某风吾起18 小时前
通过mmwave studio配置TI毫米波雷达IWR1843的StaticConfig
嵌入式硬件·学习
XDHCOM18 小时前
ORA-38456: 属性集状态不一致,Oracle报错修复对比,远程处理方案选择
数据库·oracle
羊小蜜.18 小时前
Mysql 14: 存储引擎——架构、引擎对比与锁机制
数据库·mysql·架构
EnglishJun18 小时前
ARM嵌入式学习(二十二)-- 操作系统的中断处理以及ioctl
学习
爱学习的小囧18 小时前
VM硬件版本20与17核心区别(ESXi 8.0适配+实操指南)
运维·服务器·网络·数据库·esxi·vmware·虚拟化
heimeiyingwang18 小时前
【架构实战】Redis性能调优与内存优化策略
数据库·redis·架构
南無忘码至尊18 小时前
Unity学习90天-第3天-认识触屏输入(手游基础)并完成手机点击屏幕,物体向点击位置移动
学习·unity·c#·游戏引擎·游戏开发
青桔柠薯片18 小时前
从字符设备到平台驱动:IMX6ULL LED 与蜂鸣器驱动开发学习总结
驱动开发·学习·imx6ull
Flying pigs~~18 小时前
检索增强生成RAG项目tools_04:flask➕fastapi➕高并发
数据库·python·flask·大模型·fastapi·异步
minebmw718 小时前
Oracle 19.29 中 ORA-12751 错误完全解析:从通用问题到 minact-scn 场景
数据库·oracle