下面这张图是我本身画的sql逻辑图。规定了一些画法。而后画出来是这样的。sql
由于常常要读别人的sql,又臭又长,可读性不好,因而想作一个程序自动生成的逻辑图。3d
为何不用执行语法树,由于我的以为语法树可读性也不是很高。blog
打个比方说,a join b join c ,你explain一下,就会获得执行计划是 1.a join b 2. 上一个结果 join b。select
这样对表之间关系的理解不是颇有帮助。 由于 a b c 是同一层的表。可是按照执行计划就会有前后顺序。语法
如下是对上图的解释:程序
1.每个框框是一个查询,即必定有一个select语句。im
2.箭头指向另外一框框的底部,表示是另外一个框框的子查询查询
3.箭头指向左边,表明是join操做db
4.join的条件写在箭头里。img
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表的子查询。
下面是一些规则具体说明