繁体   English   中英

在表变量中选择行是否可以防止游标在源表上锁定?

[英]Does selecting rows into a table variable prevent cursor locks on the source table?

我有一些报告,发现需要通过光标逐行进行汇编。

我知道在针对表运行时,游标通常不是一件好事,但是如果我要为表变量创建游标,是否可以防止发生行锁? 在大多数情况下,我已经找到了完全避免使用游标的方法,但是在一些报告中却没有找到解决方法。

游标不佳的原因是因为它们的性能不佳,而不是通常是因为它们导致了锁定(尽管这肯定是一个问题)。 如果在表变量上使用游标,性能问题不会消失并且锁定仍然会发生,而是在表变量表上发生。 唯一的区别是表变量不能被其他会话访问,因此可以确保它们不会在其上阻塞,这是必须的。 总体性能可能仍然会下降,因为您需要首先将数据复制到表变量中,但是,如果您主要关注的是锁,那么可以帮上忙。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM