mysql 查询的一般思路

能用单表优先用单表,即便是需要用group by、order by、limit等,效率一般也比多表高

不能用单表时优先用连接,连接是SQL中非常强大的用法,小表驱动大表+建立合适索引+合理运用连接条件,基本上连接可以解决绝大部分问题。但join级数不宜过多,毕竟是一个接近指数级增长的关联效果

能不用子查询、笛卡尔积尽量不用,虽然很多情况下MySQL优化器会将其优化成连接方式的执行过程,但效率仍然难以保证

自定义变量在复杂SQL实现中会很有用,例如LeetCode中困难级别的数据库题目很多都需要借助自定义变量实现

如果MySQL版本允许,某些带聚合功能的查询需求应用窗口函数是一个最优选择。除了经典的获取3种排名信息,还有聚合函数、向前向后取值、百分位等

相关推荐
zuoerjinshu10 小时前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
NocoBase12 小时前
【2.0 教程】第 1 章:认识 NocoBase ,5 分钟跑起来
数据库·人工智能·开源·github·无代码
Hoshino.4113 小时前
基于Linux中的数据库操作——下载与安装(1)
linux·运维·数据库
Oueii14 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
未来龙皇小蓝15 小时前
【MySQL-索引调优】11:Group by相关概念
数据库·mysql·性能优化
2401_8318249615 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python
njidf15 小时前
Python日志记录(Logging)最佳实践
jvm·数据库·python
twc82915 小时前
大模型生成 QA Pairs 提升 RAG 应用测试效率的实践
服务器·数据库·人工智能·windows·rag·大模型测试
@我漫长的孤独流浪15 小时前
Python编程核心知识点速览
开发语言·数据库·python
2401_8512729915 小时前
实战:用Python分析某电商销售数据
jvm·数据库·python