[发明专利]数据库表的加锁方法、装置、存储介质和电子设备在审
申请号: | 202110975608.6 | 申请日: | 2021-08-24 |
公开(公告)号: | CN113760932A | 公开(公告)日: | 2021-12-07 |
发明(设计)人: | 赵景波 | 申请(专利权)人: | 北京金山云网络技术有限公司 |
主分类号: | G06F16/23 | 分类号: | G06F16/23;G06F16/22;G06F21/62 |
代理公司: | 北京华夏泰和知识产权代理有限公司 11662 | 代理人: | 曾军 |
地址: | 100085 北京市海淀*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 数据库 加锁 方法 装置 存储 介质 电子设备 | ||
本发明公开了一种数据库表的加锁方法、装置、存储介质和电子设备。该方法包括:在获取到客户端请求对数据库中的目标表进行加锁的第一加锁请求的情况下,获取目标表的锁标志,其中,锁标志用于指示目标表的加锁类型;在锁标志为目标加锁标志的情况下,向客户端返回错误指令,其中,错误指令用于指示客户端访问目标表失败。本发明解决了访问数据库中的表的过程中夯住所造成的访问效率低的技术问题。
技术领域
本发明涉及计算机领域,具体而言,涉及一种数据库表的加锁方法、装置、存储介质和电子设备。
背景技术
现有技术中,在对数据库中的表进行访问的过程中,需要对表进行加锁,以免访问过程中其他用户对表进行访问造成冲突。
然而,现有技术中,如果访问的表已经被加锁,则访问请求会夯住,一直处于等待状态,造成访问数据库的表的效率低。
发明内容
本发明实施例提供了一种数据库表的加锁方法、装置、存储介质和电子设备,以至少解决访问数据库中的表的过程中夯住所造成的访问效率低的技术问题。
根据本发明实施例的第一方面,提供了一种数据库表的加锁方法,包括:在获取到客户端请求对数据库中的目标表进行加锁的第一加锁请求的情况下,获取上述目标表的锁标志,其中,上述锁标志用于指示上述目标表的加锁类型;在上述锁标志为目标加锁标志的情况下,向上述客户端返回错误指令,其中,上述错误指令用于指示上述客户端访问上述目标表失败。
根据本发明实施例的另一方面,提供了一种数据库表的加锁装置,包括:第一获取单元,用于在获取到客户端请求对数据库中的目标表进行加锁的第一加锁请求的情况下,获取上述目标表的锁标志,其中,上述锁标志用于指示上述目标表的加锁类型;第一返回单元,用于在上述锁标志为目标加锁标志的情况下,向上述客户端返回错误指令,其中,上述错误指令用于指示上述客户端访问上述目标表失败。
根据本发明实施例的又一方面,还提供了一种存储介质,该存储介质中存储有计算机程序,其中,该计算机程序被设置为运行时执行上述数据库表的加锁方法。
根据本发明实施例的又一方面,还提供了一种电子设备,包括存储器和处理器,上述存储器中存储有计算机程序,上述处理器被设置为通过上述计算机程序执行上述的数据库表的加锁方法。
在本发明实施例中,采用了在获取到客户端请求对数据库中的目标表进行加锁的第一加锁请求的情况下,获取上述目标表的锁标志,其中,上述锁标志用于指示上述目标表的加锁类型;在上述锁标志为目标加锁标志的情况下,向上述客户端返回错误指令,其中,上述错误指令用于指示上述客户端访问上述目标表失败的方法,由于在上述方法中,在对数据库中的目标表进行访问的过程中,如果目标表已经被加锁,且加锁标志为目标加锁标志,则直接返回错误指令,指示客户端访问目标表失败,避免了客户端夯住一直等待的问题,提高了对数据库中的表的访问效率。
附图说明
此处所说明的附图用来提供对本发明的进一步理解,构成本申请的一部分,本发明的示意性实施例及其说明用于解释本发明,并不构成对本发明的不当限定。在附图中:
图1是根据本发明实施例的一种可选的数据库表的加锁方法的流程图;
图2是根据本发明实施例的一种可选的数据库表的加锁方法的不同类型锁的处理示意图;
图3是根据本发明实施例的一种可选的数据库表的加锁方法的等待队列示意图;
图4是根据本发明实施例的一种可选的数据库表的加锁方法的锁兼容示意图;
图5是根据本发明实施例的另一种可选的数据库表的加锁方法的流程图;
图6是根据本发明实施例的一种可选的数据库表的加锁装置的结构示意图。
具体实施方式
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京金山云网络技术有限公司,未经北京金山云网络技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110975608.6/2.html,转载请声明来源钻瓜专利网。