[发明专利]一种分布式数据库管理方法、装置、设备、系统及介质在审
申请号: | 202210643188.6 | 申请日: | 2022-06-08 |
公开(公告)号: | CN115062041A | 公开(公告)日: | 2022-09-16 |
发明(设计)人: | 郭振岗;王海龙;韩朱忠 | 申请(专利权)人: | 上海达梦数据库有限公司 |
主分类号: | G06F16/242 | 分类号: | G06F16/242;G06F16/27 |
代理公司: | 北京品源专利代理有限公司 11332 | 代理人: | 岳晓萍 |
地址: | 201203 上海*** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 分布式 数据库 管理 方法 装置 设备 系统 介质 | ||
1.一种分布式数据库管理方法,其特征在于,应用于分布式数据库中的实例节点,包括:
接收客户端发送的第一SQL语句;
根据所述第一SQL语句,确定所述第一SQL语句对应的第一子任务并发送至数据存储节点;
接收数据存储节点反馈的第一数量的第一管理结果并生成第一挂起消息;
将所述第一管理结果反馈至客户端以及发送所述第一挂起消息至所述数据存储节点以使数据存储节点中未结束的第一工作线程挂起。
2.根据权利要求1所述的方法,其特征在于,所述根据所述第一SQL语句,确定所述第一SQL语句对应的第一子任务并发送至数据存储节点,包括:
基于查询优化器对所述第一SQL语句进行解析,生成第一计划树;
将所述第一计划树划分成至少一个第一子任务,并将所述第一子任务发送至所述数据存储节点。
3.根据权利要求1所述的方法,其特征在于,还包括:
当接收到客户端发送的第二SQL语句时,确定所述第二SQL语句对应的第二子任务,并将所述第二子任务及所生成的第二挂起消息发送至所述数据存储节点,所述第二挂起消息用于使数据存储节点中未结束的第一工作线程挂起;
接收所述数据存储节点反馈的第一数量的第二管理结果,并将所述第二管理结果反馈至客户端。
4.根据权利要求3所述的方法,其特征在于,在所述数据存储节点中未结束的第一工作线程挂起之后,还包括:
当接收到客户端发送的第一SQL语句关联的取数据命令时,将基于所述取数据命令所生成的唤醒消息发送至所述数据存储节点以使数据存储节点中已挂起的第一工作线程继续执行;
接收所述数据存储节点反馈的第二数量的第三管理结果,并将所述第三管理结果反馈至客户端。
5.一种分布式数据库管理方法,其特征在于,应用于分布式数据库中的数据存储节点,包括:
接收实例节点发送的第一子任务;
为每个所述第一子任务分配预设数量的第一工作线程并开始执行;
将执行后第一数量的第一管理结果发送至所述实例节点;
接收所述实例节点发送的第一挂起消息并将未结束的第一工作线程挂起。
6.根据权利要求5所述的方法,其特征在于,所述为每个所述子任务分配预设数量的第一工作线程并开始执行,包括:
根据所述第一子任务,生成对应的第一句柄对象和第一调度管理器,所述第一调度管理器用于管理第一句柄对象执行的上下文执行环境;
基于所述第一调度管理器对每个子任务分配预设数量的第一工作线程并开始执行。
7.根据权利要求5所述的方法,其特征在于,所述接收所述实例节点发送的挂起消息并将未结束的第一工作线程挂起,包括:
当接收到实例节点发送的第一挂起消息时,在第一调度管理器上生成挂起标记;
基于所述调度管理器确定第一句柄对象上未结束的第一工作线程;
当所述未结束的第一工作线程检查到所述挂起标记时,将未结束的第一工作线程挂起,并基于所述第一调度管理器保存第一句柄对象执行的上下文环境。
8.根据权利要求5所述的方法,其特征在于,还包括:
接收实例节点发送的第二子任务;
为每个所述第二子任务分配预设数量的第二工作线程并开始执行;
将执行后第一数量的第二管理结果发送至所述实例节点;
接收所述实例节点发送的第二挂起消息并将未结束的第二工作线程挂起。
9.根据权利要求5所述的方法,其特征在于,在将未结束的第一工作线程挂起之后,还包括:
当接收到实例节点发送的第一SQL语句关联的唤醒消息时,将所述唤醒消息关联的第一句柄对象中已挂起的第一工作线程唤醒继续执行;
将执行后的第三管理结果发送至实例节点。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于上海达梦数据库有限公司,未经上海达梦数据库有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202210643188.6/1.html,转载请声明来源钻瓜专利网。
- 上一篇:无线通信方法、装置和通信设备
- 下一篇:基于标准化类特定互信息的特征选择方法