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

为了让DBA从日常繁琐的工作中解放出来,通过SQL自助平台,可以让开发自上线,开发提交SQL后就会自动返回优化建议,无需DBA的再次审核,从而提升上线效率,有利于建立数据库开发规范。

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

SQL自动审核主要完成两方面目的:

1、避免性能太差的SQL进入生产系统,导致整体性能降低。

2、检查开发设计的索引是否合理,是否需要添加索引。

思路其实很简单:

1、获取开发提交的SQL

2、对要执行的SQL做分析,触碰事先定义好的规则来判断这个SQL是否可以自动审核通过,未通过审核的需要人工处理。

下面是首页界面:

使用说明:

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客户端进行语法校验和表是否存在等校验。

  • update审核

检查项:

1、警告!没有where条件,update会全表更新,禁止执行!!!

2、更新的行数小于10000行,可以由开发自助执行。否则请联系DBA执行!!!

防止where 1=1 绕过审核规则

必须写真实的where条件才可以执行更新操作。

上线成功的SQL会记录到一张操作日志表里,并且会把binlog位置点记录下来,方便日后的回滚操作。

  • create审核

检查项:

1、警告!表没有主键

2、警告!表主键应该是自增的,缺少AUTO_INCREMENT

3、提示:id自增字段默认值为1,auto_increment=1

4、警告!表没有索引

5、警告!表中的索引数已经超过5个,索引是一把双刃剑,它可以提高查询效率但也会降低插入和更新的速度并占用磁盘空间

6、警告!表字段没有中文注释,COMMENT应该有默认值,如COMMENT ‘姓名’

7、警告!表没有中文注释

8、警告!表缺少utf8字符集,否则会出现乱码

9、警告!表存储引擎应设置为InnoDB

10、警告!表应该为timestamp类型加默认系统当前时间

审核通过后,就可以上线了

上线失败提示:

  • alter审核

检查项:

1、警告!不支持create index语法,请更改为alter table add index语法。

2、警告!更改表结构要减少与数据库的交互次数,应改为,例alter table t1 add index IX_uid(uid),add index IX_name(name)

3、表记录小于100万行,可以由开发自助执行。否则表太大请联系DBA执行!

 

数据库上线工单查询(只记录成功执行的SQL)

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/241635.html<

(0)
运维的头像运维
上一篇2025-04-24 10:28
下一篇 2025-04-24 10:29

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注