sql生成可读性逻辑图
2021/5/30 8:20:05
本文主要是介绍sql生成可读性逻辑图,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
下面这张图是我自己画的sql逻辑图。规定了一些画法。然后画出来是这样的。
因为经常要读别人的sql,又臭又长,可读性很差,于是想做一个程序自动生成的逻辑图。
为什么不用执行语法树,因为个人觉得语法树可读性也不是很高。
打个比方说,a join b join c ,你explain一下,就会得到执行计划是 1.a join b 2. 上一个结果 join b。
这样对表之间关系的理解不是很有帮助。 因为 a b c 是同一层的表。但是按照执行计划就会有先后顺序。
以下是对上图的解释:
1.每一个框框是一个查询,即一定有一个select语句。
2.箭头指向另一框框的底部,表示是另一个框框的子查询
3.箭头指向左边,代表是join操作
4.join的条件写在箭头里。
5.每一个框框代表一个select,且是单张表的查询,框框里附带上 select xxx+group by+where
举例:select a.id,max(b.age) from a join b group by a.id
则先将sql转化成
select a.id,max(b.age) from (select * from a) join (select * from b)on a.id=b.id where b.id>1 group by a.id
则结果表是 select aid,max(bage) from tmp where bid>1 group by a.id, 在tmp的框框里写上 select xxx+group by+where
而tmp表是(a join b )形成,所以 (a join b)是tmp表的子查询。
下面是一些规则具体说明
作者:肥仔佳文猪
出处:https://www.cnblogs.com/feizaijiawenzhu/p/14823799.html
这篇关于sql生成可读性逻辑图的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-24怎么修改Kafka的JVM参数?-icode9专业技术文章分享
- 2024-12-23线下车企门店如何实现线上线下融合?
- 2024-12-23鸿蒙Next ArkTS编程规范总结
- 2024-12-23物流团队冬至高效运转,哪款办公软件可助力风险评估?
- 2024-12-23优化库存,提升效率:医药企业如何借助看板软件实现仓库智能化
- 2024-12-23项目管理零负担!轻量化看板工具如何助力团队协作
- 2024-12-23电商活动复盘,为何是团队成长的核心环节?
- 2024-12-23鸿蒙Next ArkTS高性能编程实战
- 2024-12-23数据驱动:电商复盘从基础到进阶!
- 2024-12-23从数据到客户:跨境电商如何通过销售跟踪工具提升营销精准度?