GET_XACT_SHARED_LOCK(name_expr [, timeout_expr])
功能:GET_XACT_SHARED_LOCK(name_expr[, timeout_expr]) 为一个事务获取一把锁名为name_expr的共享咨询锁,若获取成功返回TRUE,之后另一个事务也可调用GET_XACT_SHARED_LOCK(name_expr)获取该同名锁,如果该同名锁被其他事务锁为排他咨询锁时,将会等待timeout_expr秒,在此期间如果该排他锁被释放,则获取成功,否则获取失败。
GET_XACT_SHARED_LOCK(name_expr[, timeout_expr])的返回值如下:
· TRUE: 成功获取到锁。
· FALSE: 未能获取到锁。
通过GET_XACT_SHARED_LOCK(name_expr[, timeout_expr])获取到的锁可通过以下方式释放:
· 隐式释放: 事务/会话中断(不论正常或异常)时该事务/会话占有的锁自动释放。
· 通过TRY_GET_XACT_SHARED_LOCK(name_expr)尝试获取名为name_expr的共享咨询锁,无论获取成功或者失败都立刻返回。
说明:
· 表示锁名的name_expr的计算结果的字符串长度不能超过64字节。
· 同一个事务同时最多可以加32把锁。
· 同一事务可以多次对同一个锁名上锁,在事务/会话结束时会主动释放,无需显示释放。对同一锁名多次加锁时,第二次加锁开始的次数并不计入上述所说的32把锁的个数中。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。