[发明专利]一种基于复杂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中运行有报错消息,则输出所述报错消 息。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于蜂助手股份有限公司,未经蜂助手股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/202011160947.0/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top