首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >"Set Transaction Level“是否需要begin transaction?

"Set Transaction Level“是否需要begin transaction?
EN

Stack Overflow用户
提问于 2010-12-10 23:14:32
回答 2查看 1.4K关注 0票数 4

在MS SQL Server中,如果我在存储过程中使用"SET TRANSACTION ISOLATION LEVEL“,是否需要将select语句包装在BEGIN/END TRANSACTION块中?下面的工作会像预期的那样工作吗?

代码语言:javascript
复制
CREATE PROCEDURE my_sproc AS
BEGIN

    SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED

    SELECT * FROM MyTable

END
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-12-10 23:17:46

TRANSACTION ISOLATION LEVEL设置是连接级设置。不需要将其包装在事务中。

这就是说,你知道你会从这个设置中有脏读和类似的东西吗?

您可以通过使用锁定提示在逐个查询的基础上完成相同的操作,例如:

SELECT * FROM MyTable WITH (NOLOCK)

票数 4
EN

Stack Overflow用户

发布于 2010-12-10 23:18:18

设置事务隔离级别与BEGIN/COMMIT/ROLLBACK不同

  • 第一个更改隔离与并发设置
  • 第二个定义原子“工作单元”

没有直接的联系或交互:不同的概念

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4410232

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档