[发明专利]一种基于复杂SQL的自动优化方法和装置有效
申请号: | 202011160947.0 | 申请日: | 2020-10-27 |
公开(公告)号: | CN112347120B | 公开(公告)日: | 2022-04-01 |
发明(设计)人: | 陈建成;廖阳春;郑广彬 | 申请(专利权)人: | 蜂助手股份有限公司 |
主分类号: | G06F16/242 | 分类号: | G06F16/242;G06F16/2453 |
代理公司: | 广州睿金泽专利代理事务所(普通合伙) 44430 | 代理人: | 宋伟文 |
地址: | 510635 广东省广州市天河区龙*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 复杂 sql 自动 优化 方法 装置 | ||
1.一种基于复杂SQL的自动优化方法,其特征在于,包括:
接收并从中筛选具有优化特征的SQL语句;具体包括:将所述SQL语句发送给SQLServer执行并记录执行耗时,若触发优化特征阀值,则所述SQL语句符合所述优化特征;
根据基本规则,检验所述SQL语句的正确性;
对所述SQL语句遍历所有优化规则,优化所述SQL语句;
输出优化后的所述SQL语句并记录耗时;
生成优化报告,并记录到数据库;同时还对优化前后的执行效果进行记录,与优化记录一起形成优化报告,展示给开发人员,方便开发人员对优化前后的脚本进行监控;
其中,所述优化特征包括以下至少一项:执行出错、影响执行效率、执行顺序有问题、执行耗时长、索引问题导致全表查询、丢失索引、嵌套多级子查询;所述优化报告包括如下字段:应用程序、数据库类型、SQL语句、执行耗时、问题描述;
所述优化规则包括普通优化规则和自定义优化规则,其中所述普通优化规则包括:若所述SQL语句中包含select*语句,则将*替换为对应的表字段;
若所述SQL语句进行全表扫描操作,则在where子句中使用!=或操作符;
若where子句中对字段进行操作,则在where子句中对字段进行函数操作;
若where子句中使用索引,则在where子句中的“=”左边进行函数、算术运算或其他表达式运算;
若where子句中含有操作符in,则用操作符exists代替操作符in。
2.根据权利要求1所述的一种基于复杂SQL的自动优化方法,其特征在于,
所述根据基本规则,检验所述SQL语句的正确性,具体包括:
将所述SQL语句发送给SQL Server,
若所述SQL语句在SQL Server中运行不报错,则所述SQL语句正确;
若所述SQL语句在SQL Server中运行有报错消息,则输出所述报错消 息。
3.一种基于复杂SQL的自动优化装置,其特征在于,采用权利要求1的方法,包括:
接收筛选模块,接收并从中筛选具有优化特征的SQL语句;具体包括:
将所述SQL语句发送给SQL Server执行并记录执行耗时,若触发优化特征阀值,则所述SQL语句符合所述优化特征;
验证模块,用于根据基本规则,检验所述SQL语句的正确性;
优化模块,用于对所述SQL语句遍历所有优化规则,优化所述SQL语句;
输出模块,用于输出优化后的所述SQL语句;
监控模块,用于监控优化后的所述SQL语句的执行耗时;
报告生成模块,用于生成SQL优化报告;同时还对优化前后的执行效果进行记录,与优化记录一起形成优化报告,展示给开发人员,方便开发人员对优化前后的脚本进行监控;
其中,所述优化特征包括以下至少一项:执行出错、影响执行效率、执行顺序有问题、执行耗时长、索引问题导致全表查询、丢失索引、嵌套多级子查询;所述优化报告包括如下字段:应用程序、数据库类型、SQL语句、执行耗时、问题描述。
4.根据权利要求3所述的一种基于复杂SQL的自动优化装置,其特征在于所述优化规则包括普通优化规则和自定义优化规则。
5.根据权利要求4所述的一种基于复杂SQL的自动优化装置,其特征在于,所述普通优化规则包括:
若所述SQL语句中包含select*语句,则将*替换为对应的表字段;
若所述SQL语句进行全表扫描操作,则在where子句中使用!=或操作符;
若where子句中对字段进行操作,则在where子句中对字段进行函数操作;
若where子句中使用索引,则在where子句中的“=”左边进行函数、算术运算或其他表达式运算;
若where子句中含有操作符in,则用操作符exists代替操作符in。
6.根据权利要求3所述的一种基于复杂SQL的自动优化装置,其特征在于,检验所述SQL语句的正确性,具体包括:
将所述SQL语句发送给SQL Server,
若所述SQL语句在SQL Server中运行不报错,则所述SQL语句正确;
若所述SQL语句在SQL Server中运行有报错消息,则输出所述报错消 息。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于蜂助手股份有限公司,未经蜂助手股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202011160947.0/1.html,转载请声明来源钻瓜专利网。