当前位置:Gxlcms > 数据库问题 > SQL自动审核-自助上线平台

SQL自动审核-自助上线平台

时间:2021-07-01 10:21:17 帮助过:214人阅读


借鉴了去哪网Inception的思路并且把美团网SQLAdvisor(索引优化建议)集成在一起,并结合了之前写的《DBA的40条军规》纳入了审核规则里,用PHP实现。目前在我公司内部使用。


下面是首页界面:

技术分享图片


使用说明:

1、针对select/insert/update/create/alter加了规则,delete需要审批。

2、语句之间要有空格,例where id = 100,没有空格会影响判断的准确性。

3、SQL语句后面要加分号; MySQL解析器规定分号才可以执行SQL。

4、反引号`可能会造成上线失败,需要用文本编辑器替换掉。

5、支持多条SQL解析,用######六个井号分割。


  • SELECT审核

1、开发人员可以直接将SQL语句提交到平台进行风险评估

2、平台对SQL语句进行分析,自动给出其不符合开发规范的改进意见

3、适用场景:应用开发阶段

检查项:

1、select * 是否有必要查询所有的字段?
2、警告!没有where条件,注意where后面的字段要加上索引
3、没有limit会查询更多的数据
4、警告!子查询性能低下,请转为join表关联
5、提示:in里面的数值不要超过1000个
6、提示:采用join关联,注意关联字段要都加上索引,如on a.id=b.id
7、提示:MySQL对多表join关联性能低下,建议不要超过3个表以上的关联
8、警告!like '%%'双百分号无法用到索引,like 'mysql%'这样是可以利用到索引的
9、提示:默认情况下,MySQL对所有GROUP BY col1,col2...的字段进行排序。如果查询包括GROUP BY,
想要避免排序结果的消耗,则可以指定ORDER BY NULL禁止排序。
10、警告!MySQL里用到order by rand()在数据量比较多的时候是很慢的,因为会导致MySQL全表扫描,故也不会用到索引
11、提示:是否要加一个having过滤下?
12、警告!禁止不必要的order by排序,因为前面已经count统计了
13、警告!MySQL里不支持函数索引,例DATE_FORMAT('create_time','%Y-%m-%d')='2016-01-01'是无法用到索引的,需要改写为
create_time>='2016-01-01 00:00:00' and create_time<='2016-01-01 23:59:59'

之后会调用美团网SQLAdvisor进行索引检查


使用概述:

技术分享图片

1、选中你的数据库名字
2、在对话框中输入你要提交的SQL
3、点击提交审核按钮


技术分享图片

提交以后,系统自动返回SQL优化改进意见。



  • insert审核

检查项:

1、警告: insert 表1 select 表2,会造成锁表。

技术分享图片

审核通过以后,会弹出用户名和密码,提示上线:

技术分享图片

点击我要上线按钮,会调用MySQL客户端进行语法校验和表是否存在等校验。

技术分享图片




SQL自动审核-自助上线平台

标签:审核   inception   sql   

人气教程排行