[发明专利]一种SQL优化方法及设备有效
| 申请号: | 201710772704.4 | 申请日: | 2017-08-31 |
| 公开(公告)号: | CN107704511B | 公开(公告)日: | 2019-09-06 |
| 发明(设计)人: | 陈振强;熊仲健 | 申请(专利权)人: | 星环信息科技(上海)有限公司 |
| 主分类号: | G06F16/2453 | 分类号: | G06F16/2453;G06F16/242 |
| 代理公司: | 上海百一领御专利代理事务所(普通合伙) 31243 | 代理人: | 佘猛;邵栋 |
| 地址: | 200233 上海市*** | 国省代码: | 上海;31 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 一种 sql 优化 方法 设备 | ||
1.一种SQL优化方法,其中,所述方法包括:
确定SQL语句中的至少一个待优化的查询块,包括:通过词法、语法和语义分析对获取的SQL语句进行分析,得到包含有所述SQL语句中的所有查询块及其引用点、所述引用点的引用列及其对应的所述引用列的有效过滤表达式的中间表示信息;遍历并识别所述中间表示信息,得到所述SQL语句中的至少一个待优化的查询块,其中,所述待优化的查询块包括其引用点、所述引用点的引用列及其对应的所述引用列的有效过滤表达式;
分别对每个所述待优化的查询块进行分析提取,得到每个所述待优化的查询块对应的过滤条件,包括:分别对所述至少一个所述待优化的查询块中的每个所述待优化的查询块进行分析提取,得到每个所述待优化的查询块中的至少一个所述引用列在其对应的所有所述引用点的有效过滤表达式;在每个所述待优化的查询块中,分别将每个所述引用列在其对应的所有所述引用点的有效过滤表达式通过或运算连接,得到每个所述引用列对应的合并过滤表达式,并将每个所述引用列对应的合并过滤表达式通过与运算连接,得到每个所述待优化的查询块对应的过滤条件;
分别基于每个所述过滤条件对对应的所述待优化的查询块进行优化,得到所述SQL语句中的每个优化后的查询块,对应得到优化后的SQL语句。
2.根据权利要求1所述的方法,其中,所述引用列的有效过滤表达式满足如下条件:
一个所述引用列作为所述有效过滤表达式的变量;且,
遍历所述有效过滤表达式的父节点,直至根节点,仅存在与运算。
3.根据权利要求1所述的方法,其中,所述分别基于每个所述过滤条件对对应的所述待优化的查询块进行优化,得到所述SQL语句中的每个优化后的查询块,对应得到优化后的SQL语句,包括:
分别将每个所述过滤条件下推到对应的所述待优化的查询块中,对对应的所述待优化的查询块进行优化,得到所述SQL语句中的每个待优化的查询块对应的优化后的查询块;
基于所述SQL语句中的每个待优化的查询块对应的优化后的查询块,对应得到优化后的SQL语句。
4.根据权利要求1所述的方法,其中,所述分别对每个所述待优化的查询块进行分析提取,得到每个所述待优化的查询块对应的过滤条件的同时,还包括:
对所述SQL语句及其中的至少一个待优化的查询块进行编译;
所述分别基于每个所述过滤条件对对应的所述待优化的查询块进行优化,得到所述SQL语句中的每个优化后的查询块,对应得到优化后的SQL语句之后,还包括:
对所述优化后的SQL语句进行重编译并执行。
5.根据权利要求1至4中任一项所述的方法,其中,所述待优化的查询块包括以下至少任一项:
子查询查询块、视图查询块及数据表查询块。
6.一种SQL优化设备,其中,所述设备包括:
确定装置,用于确定SQL语句中的至少一个待优化的查询块,包括:通过词法、语法和语义分析对获取的SQL语句进行分析,得到包含有所述SQL语句中的所有查询块及其引用点、所述引用点的引用列及其对应的所述引用列的有效过滤表达式的中间表示信息;遍历并识别所述中间表示信息,得到所述SQL语句中的至少一个待优化的查询块,其中,所述待优化的查询块包括其引用点、所述引用点的引用列及其对应的所述引用列的有效过滤表达式;
提取装置,用于分别对每个所述待优化的查询块进行分析提取,得到每个所述待优化的查询块对应的过滤条件,包括:分别对所述至少一个所述待优化的查询块中的每个所述待优化的查询块进行分析提取,得到每个所述待优化的查询块中的至少一个所述引用列在其对应的所有所述引用点的有效过滤表达式;在每个所述待优化的查询块中,分别将每个所述引用列在其对应的所有所述引用点的有效过滤表达式通过或运算连接,得到每个所述引用列对应的合并过滤表达式,并将每个所述引用列对应的合并过滤表达式通过与运算连接,得到每个所述待优化的查询块对应的过滤条件;
优化装置,用于分别基于每个所述过滤条件对对应的所述待优化的查询块进行优化,得到所述SQL语句中的每个优化后的查询块,对应得到优化后的SQL语句。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于星环信息科技(上海)有限公司,未经星环信息科技(上海)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201710772704.4/1.html,转载请声明来源钻瓜专利网。
- 上一篇:信息处理方法
- 下一篇:基于社交数据的金融产品推荐方法、电子装置及介质





