[发明专利]一种数据库SQL语句优化方法及装置有效
申请号: | 201810381164.1 | 申请日: | 2018-04-25 |
公开(公告)号: | CN108628975B | 公开(公告)日: | 2020-08-21 |
发明(设计)人: | 万伟;张钦;朱仲颖 | 申请(专利权)人: | 上海达梦数据库有限公司 |
主分类号: | G06F16/242 | 分类号: | G06F16/242;G06F16/2453;G06F16/2455 |
代理公司: | 北京品源专利代理有限公司 11332 | 代理人: | 孟金喆 |
地址: | 201203 上海*** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 数据库 sql 语句 优化 方法 装置 | ||
本发明公开了一种数据库SQL语句优化方法及装置。该方法包括:获取用户输入的数据库SQL语句;若数据库SQL语句中存在查询项,则依次判断数据库SQL语句中是否存在去重关键字和分组子句;若数据库SQL语句中存在去重关键字和分组子句,则获取数据库SQL语句中的分组项;若查询项包含数据库SQL语句中的全部分组项,则判断数据库SQL语句中是否存在分组统计数据子句;若数据库SQL语句中不存在分组统计数据子句,则将数据库SQL语句中的去重关键字删除生成新的数据库SQL语句,并执行新的数据库SQL语句,通过本发明的技术方案,能够实现检测出可以进行消除DISTINCT关键字的数据库SQL语句,并对检测出的数据库SQL语句进行优化的效果。
技术领域
本发明实施例涉及计算机技术,尤其涉及一种数据库SQL语句优化方法及装置。
背景技术
SQL语言,是结构化查询语言(Structured Query Language)的简称。SQL语言是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。
结构化查询语言(Structured Query Language,SQL语言)是最重要也是最常用的关系数据库操作语言,DISTINCT关键字是SQL标准中用来去除重复数据的关键字。
在当前通用的数据库技术中,为了实现去除重复数据的效果,不管语句所对应的表结构和数据特征,都需要将表中的数据取出来,按照DISTINCT关键字指定的去重项来计算。但是,在某些特定情况下,是不需要经过“计算去重”这一步骤也可以得到相同结果的,若使用当前通用的数据库技术则会导致增加处理的复杂度。
发明内容
本发明提供一种数据库SQL语句优化方法及装置,以实现检测出可以进行消除DISTINCT关键字的数据库SQL语句,并对检测出的数据库语句进行优化的效果。
第一方面,本发明实施例提供了一种数据库SQL语句优化方法,该方法包括:获取用户输入的数据库SQL语句;
若所述数据库SQL语句中存在查询项,则依次判断所述数据库SQL语句中是否存在去重关键字和分组子句;
若所述数据库SQL语句中存在所述去重关键字和所述分组子句,则获取所述数据库SQL语句中的分组项;
若所述查询项包含所述数据库SQL语句中的全部分组项,则判断所述数据库SQL语句中是否存在分组统计数据子句;
若所述数据库SQL语句中不存在所述分组统计数据子句,则将所述数据库SQL语句中的去重关键字删除生成新的数据库SQL语句,并执行所述新的数据库SQL语句。
进一步的,还包括:
若所述数据库SQL语句中存在去重关键字,且不存在所述分组子句,则判断所述查询项中是否存在聚集函数;
若所述查询项中存在所述聚集函数,则将所述数据库SQL语句中的去重关键字删除生成新的数据库SQL语句,并执行所述新的数据库SQL语句。
进一步的,还包括:
若所述数据库SQL语句中不存在所述去重关键字,则执行所述数据库SQL语句。
进一步的,若所述数据库SQL语句中存在所述分组统计数据子句,则执行所述数据库SQL语句。
进一步的,所述去重关键字为DISTINCT。
进一步的,所述分组子句包括:GROUP BY子句。
进一步的,所述分组统计数据子句包括:GROUP BY ROLLUP子句和/或GROUP BYCUBE子句。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于上海达梦数据库有限公司,未经上海达梦数据库有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810381164.1/2.html,转载请声明来源钻瓜专利网。