[发明专利]一种子查询处理方法、装置、设备及存储介质在审
申请号: | 202010928464.4 | 申请日: | 2020-09-07 |
公开(公告)号: | CN112100207A | 公开(公告)日: | 2020-12-18 |
发明(设计)人: | 朱仲颖;望声宜;韩朱忠 | 申请(专利权)人: | 上海达梦数据库有限公司 |
主分类号: | G06F16/2453 | 分类号: | G06F16/2453;G06F16/242 |
代理公司: | 北京品源专利代理有限公司 11332 | 代理人: | 孟金喆 |
地址: | 201203 上海*** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 种子 查询 处理 方法 装置 设备 存储 介质 | ||
1.一种子查询处理方法,其特征在于,包括:
若当前子查询为相关子查询,则获取引用外层查询对象的列定义的数据类型;
若所述数据类型为预设数据类型,则将所述当前子查询所属布尔表达式或者查询表达式转换为临时命名函数。
2.根据权利要求1所述的方法,其特征在于,在获取引用外层查询对象的列定义的数据类型之前,还包括:
获取引用外层查询对象的列;
若所述数据类型为预设数据类型,则将所述当前子查询所属布尔表达式或者查询表达式转换为临时命名函数之后,还包括:
获取所述当前子查询对应的原始语句;
将所述原始语句中所述当前子查询所在的位置改写为临时命名函数的调用,其中,所述调用函数对应的调用参数为所述当前子查询引用外层查询对象的列。
3.根据权利要求1所述的方法,其特征在于,若当前子查询为相关子查询,则获取引用外层查询对象的列定义的数据类型包括:
判断当前子查询是否引用外层查询对象的列;
若所述当前子查询引用外层查询对象的列,则所述当前子查询为相关子查询;
获取引用外层查询对象的列定义的数据类型。
4.根据权利要求1所述的方法,其特征在于,将所述当前子查询所属查询表达式转换为临时命名函数包括:
若所述当前子查询属于查询表达式,则根据所述当前子查询中引用外层查询列的个数和数据类型确定临时命名函数对应参数的个数和数据类型,其中,所述临时命名函数每一个参数对应一个引用外层查询对象的列,所述临时命名函数的定义体为赋值子句。
5.根据权利要求1所述的方法,其特征在于,将所述当前子查询所属布尔表达式转换为临时命名函数包括:
若所述当前子查询属于布尔表达式,则根据所述当前子查询所属布尔表达式中引用外层查询对象的列的个数和数据类型确定临时命名函数对应参数的个数和数据类型,其中,所述临时命名函数每一个参数对应一个引用外层查询对象的列,所述临时命名函数的定义体为条件子句。
6.一种子查询处理装置,其特征在于,包括:
第一获取模块,用于若当前子查询为相关子查询,则获取引用外层查询对象的列定义的数据类型;
第二获取模块,用于若所述数据类型为预设数据类型,则将所述当前子查询所属布尔表达式或者查询表达式转换为临时命名函数。
7.根据权利要求6所述的装置,其特征在于,还包括:
第三获取模块,用于在获取引用外层查询对象的列定义的数据类型之前,获取引用外层查询对象的列;
还包括:
第四获取模块,用于在若所述数据类型为预设数据类型,则将所述当前子查询所属布尔表达式或者查询表达式转换为临时命名函数之后,获取所述当前子查询对应的原始语句;
改写模块,用于将所述原始语句中所述当前子查询所在的位置改写为临时命名函数的调用,其中,所述调用函数对应的调用参数为所述当前子查询引用外层查询对象的列。
8.根据权利要求6所述的装置,其特征在于,第一获取模块具体用于:
判断当前子查询是否引用外层查询对象的列;
若所述当前子查询引用外层查询对象的列,则所述当前子查询为相关子查询;
获取引用外层查询对象的列定义的数据类型。
9.一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现如权利要求1-5中任一所述的方法。
10.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-5中任一所述的方法。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于上海达梦数据库有限公司,未经上海达梦数据库有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202010928464.4/1.html,转载请声明来源钻瓜专利网。
- 上一篇:一种同步开关底进水三切换排水阀芯
- 下一篇:一种折叠式储烟框