下面这张图是我自己画的sql逻辑图。规定了一些画法。然后画出来是这样的。

因为经常要读别人的sql,又臭又长,可读性很差,于是想做一个程序自动生成的逻辑图。

为什么不用执行语法树,因为个人觉得语法树可读性也不是很高。

打个比方说,a join b join c ,你explain一下,就会得到执行计划是 1.a join b 2. 上一个结果 join b。

这样对表之间关系的理解不是很有帮助。 因为  a b c 是同一层的表。但是按照执行计划就会有先后顺序。

sql生成可读性逻辑图-LMLPHP

 以下是对上图的解释:

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表的子查询。 

下面是一些规则具体说明

sql生成可读性逻辑图-LMLPHP

 sql生成可读性逻辑图-LMLPHP

sql生成可读性逻辑图-LMLPHP

sql生成可读性逻辑图-LMLPHP

 sql生成可读性逻辑图-LMLPHP

sql生成可读性逻辑图-LMLPHP

 sql生成可读性逻辑图-LMLPHP

05-29 08:07