[发明专利]一种数据库SQL语句优化方法及装置有效
申请号: | 201810381164.1 | 申请日: | 2018-04-25 |
公开(公告)号: | CN108628975B | 公开(公告)日: | 2020-08-21 |
发明(设计)人: | 万伟;张钦;朱仲颖 | 申请(专利权)人: | 上海达梦数据库有限公司 |
主分类号: | G06F16/242 | 分类号: | G06F16/242;G06F16/2453;G06F16/2455 |
代理公司: | 北京品源专利代理有限公司 11332 | 代理人: | 孟金喆 |
地址: | 201203 上海*** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 数据库 sql 语句 优化 方法 装置 | ||
1.一种数据库SQL语句优化方法,其特征在于,包括:
获取用户输入的数据库SQL语句;
若所述数据库SQL语句中存在查询项,则依次判断所述数据库SQL语句中是否存在去重关键字和分组子句;
若所述数据库SQL语句中存在所述去重关键字和所述分组子句,则获取所述数据库SQL语句中的分组项;
若所述查询项包含所述数据库SQL语句中的全部分组项,则判断所述数据库SQL语句中是否存在分组统计数据子句;
若所述数据库SQL语句中不存在所述分组统计数据子句,则将所述数据库SQL语句中的去重关键字删除生成新的数据库SQL语句,并执行所述新的数据库SQL语句;
其中,还包括:
若所述数据库SQL语句中存在去重关键字,且不存在所述分组子句,则判断所述查询项中是否存在聚集函数;
若所述查询项中存在所述聚集函数,则将所述数据库SQL语句中的去重关键字删除生成新的数据库SQL语句,并执行所述新的数据库SQL语句。
2.根据权利要求1所述的方法,其特征在于,还包括:
若所述数据库SQL语句中不存在所述去重关键字,则执行所述数据库SQL语句。
3.根据权利要求1所述的方法,其特征在于,若所述数据库SQL语句中存在所述分组统计数据子句,则执行所述数据库SQL语句。
4.根据权利要求1所述的方法,其特征在于,所述去重关键字为DISTINCT。
5.根据权利要求1所述的方法,其特征在于,所述分组子句包括:GROUP BY子句。
6.根据权利要求1所述的方法,其特征在于,所述分组统计数据子句包括:GROUP BYROLLUP子句和/或GROUP BY CUBE子句。
7.一种数据库SQL语句优化装置,其特征在于,包括:
获取模块,用于获取用户输入的数据库SQL语句;
第一判断模块,用于若所述数据库SQL语句中存在查询项,则依次判断所述数据库SQL语句中是否存在去重关键字和分组子句;
第二判断模块,用于若所述数据库SQL语句中存在所述去重关键字和所述分组子句,则获取所述数据库SQL语句中的分组项;
第三判断模块,用于若所述查询项包含所述数据库SQL语句中的全部分组项,则判断所述数据库SQL语句中是否存在分组统计数据子句;
第一执行模块,用于若所述数据库SQL语句中不存在所述分组统计数据子句,则将所述数据库SQL语句中的去重关键字删除生成新的数据库SQL语句,并执行所述新的数据库SQL语句;
其中,还包括:
第四判断模块,用于若所述数据库SQL语句中存在去重关键字,且不存在所述分组子句,则判断所述查询项中是否存在聚集函数;
第二执行模块,用于若所述查询项中存在所述聚集函数,则将所述数据库SQL语句中的去重关键字删除生成新的数据库SQL语句,并执行所述新的数据库SQL语句。
8.根据权利要求7所述的装置,其特征在于,还包括:
第三执行模块,用于若所述数据库SQL语句中不存在所述去重关键字,则执行所述数据库SQL语句。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于上海达梦数据库有限公司,未经上海达梦数据库有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810381164.1/1.html,转载请声明来源钻瓜专利网。