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

相关推荐
m0_37761823几秒前
老旧电脑适合用哪种HTML函数工具_低配设备适配方法【方法】
jvm·数据库·python
小夏子_riotous几秒前
Docker学习路径——4、制作/更改镜像
学习·docker
2143965几秒前
宝塔面板网站无法发邮件怎么办_检查PHP函数与SMTP配置
jvm·数据库·python
2401_883600253 分钟前
Golang bufio怎么读取用户输入_Golang标准输入读取教程【详解】
jvm·数据库·python
pele5 分钟前
Python Flask如何实现用户登录_基于JWT令牌的身份验证机制实现
jvm·数据库·python
m0_493934535 分钟前
HTML怎么显示网络中断恢复提示_HTML“重新连接中…”文本【操作】
jvm·数据库·python
Absurd5871 小时前
JavaScript中模块化在游戏引擎开发中的资源调度作用
jvm·数据库·python
2301_815279522 小时前
SQL如何利用聚合函数生成业务分析指标_KPI计算基础教程
jvm·数据库·python
qq_330037992 小时前
mysql如何排查Out of memory错误_mysql内存分配调优
jvm·数据库·python
weixin_458580123 小时前
如何在 Go 中直接将 AST 编译为可执行二进制文件?
jvm·数据库·python