Asp.net core 学习笔记 ( ef core transaction scope & change level )
更新: 2020-02-21
补上一些忧虑
public async Task Inside()
{
using var scope = SqlCommonMethod.CreateTransactionScope();
await SqlCommonMethod.SetIsolationLevel(Db, IsolationLevel.Serializable); // 开启高级别锁
var countries = await Db.Countries.ToListAsync(); // counties 表被高级锁了
await SqlCommonMethod.SetIsolationLevel(Db, IsolationLevel.ReadCommitted); // 设置回普通锁, 不然接下来都会一直是高级锁
await Inside2();
scope.Complete(); // 这里的 complete 结束并不会解锁, 会一直等到最外面的 scope 被释放, 符合逻辑
} public async Task Inside2()
{
using var scope = SqlCommonMethod.CreateTransactionScope();
var countries = await Db.States.ToListAsync(); // // states 表被普通锁了
scope.Complete();
} #region Simple test
[HttpPost("simple-test")]
public async Task<IActionResult> SimpleTest()
{
using (var scope = SqlCommonMethod.CreateTransactionScope())
{
await Inside();
scope.Complete(); // 这里依然不会解锁, 要等到 scope 释放
}
// 直到 using 结束才会解锁 table 哦
return Ok("ok");
}
总结 : 每次设置级别后最好是设置回去. 不然全场都会使用高级锁.
ef core 有 unit of work 的概念,当我们 save change 时会自动使用 transaction 确保更新的一致性. 隔离级别是默认的 read committed 不允许脏读.
但是呢, 有时候我们希望拥有更好的隔离级别, 比如 repeatable read, serializable
那么就需要调用 database.beginTransaction 了.
一旦需要自己控制 trans 麻烦就跟着来了。
比如在多个服务嵌套调用时, 如何共享 trans 呢 ?
每个服务的 trans 级别也有可能是不同的.
如果我们单纯使用 beginTransaction 那么需要在每个服务写判断,是否有 current transaction 做出不同的处理.
在早期, 我们会用 transaction scope 作为业务级别的事务.
transaction scope 非常强大, 可以跨库, 分布式, 甚至可以链接 file system
比如一个事务内做了数据库修改,也创建了 file, 如果事务最终失败,连 file 也可以 rollback 删除掉.
但自从 ef 出现后, 这个就变得大材小用了些. ef 也不推荐我们使用了 refer https://docs.microsoft.com/zh-cn/ef/ef6/saving/transactions?redirectedfrom=MSDN

ef core 在 2.1 的时候支持了 transactionscope 但是不支持分布式, 好像是不兼容 linux 所以去掉了.
但是在我说的这种情况下,使用它依然会让代码变得更好.
调用起来是这样的
using (var scope = new TransactionScope(
scopeOption: TransactionScopeOption.Required,
transactionOptions: new TransactionOptions { IsolationLevel = System.Transactions.IsolationLevel.RepeatableRead },
asyncFlowOption: TransactionScopeAsyncFlowOption.Enabled
))
{
try
{ }
catch (Exception ex)
{
return BadRequest(ex.Message);
}
scope.Complete();
}
默认隔离级别是 serializable.
如果想在 service 里面嵌套, 那么重要设定 scopeOption 是 required 就可以了.
它还有另外 2 个选择, 1 个是 new 意思是另外开启一个独立的 trans, 再一个是 suppend 就是完全没有 trans 无关.
有了这些就很灵活了,在不同 service 中我们可以去实现独立或无关的事务处理.
使用过程中需要注意几件事情

嵌套 scope 需要使用同一种级别
这个挺麻烦的,通常不可能全部一个级别吧...
目前没有看到方法可以修改的,一个可能的办法是直接调用 sql 语句
set transaction isolation level read committed
set transaction isolation level repeatable read;
set transaction isolation level serializable
去设定它.
这里顺便说说 sql server 对于这一块的处理.
https://www.cnblogs.com/keatkeat/p/11830113.html
另一个要注意的是, 一定要设置 async enabled 如果 scope 内需要 async 的话
asyncFlowOption: TransactionScopeAsyncFlowOption.Enabled
refer :
https://www.cnblogs.com/csdbfans/p/transactionscope.html
https://blog.csdn.net/qin_yu_2010/article/details/86150247
https://docs.microsoft.com/en-us/ef/core/saving/transactions
https://www.cnblogs.com/taiyonghai/p/6047849.html
https://www.21cto.com/article/1075
https://www.codeproject.com/Articles/690136/All-About-TransactionScope#hBusinessTrans
https://codewala.net/2018/05/06/transactionscope-a-simple-way-to-handle-transactions-in-net/
Asp.net core 学习笔记 ( ef core transaction scope & change level )的更多相关文章
- Asp.net core 学习笔记 ( ef core )
更新 : 2018-11-26 这里记入一下关于 foreignKey cascade action 默认情况下如果我们使用 data annotation required + foreginkey ...
- Asp.net core 学习笔记 ef core Surrogate Key, Natural Key, Alternate Keys
更新: 2019-12-23 foreignkey 并不一样要配上 alternate key,其实只要是 unique 就可以了. 和 sql server 是一样的, 经常有一种错觉 primar ...
- Asp.Net Core学习笔记:入门篇
Asp.Net Core 学习 基于.Net Core 2.2版本的学习笔记. 常识 像Django那样自动检查代码更新,自动重载服务器(太方便了) dotnet watch run 托管设置 设置项 ...
- .NET CORE学习笔记系列(2)——依赖注入[6]: .NET Core DI框架[编程体验]
原文https://www.cnblogs.com/artech/p/net-core-di-06.html 毫不夸张地说,整个ASP.NET Core框架是建立在一个依赖注入框架之上的,它在应用启动 ...
- .NET CORE学习笔记系列(2)——依赖注入【3】依赖注入模式
原文:https://www.cnblogs.com/artech/p/net-core-di-03.html IoC主要体现了这样一种设计思想:通过将一组通用流程的控制权从应用转移到框架中以实现对流 ...
- .NET CORE学习笔记系列(2)——依赖注入【1】控制反转IOC
原文:https://www.cnblogs.com/artech/p/net-core-di-01.html 一.流程控制的反转 IoC的全名Inverse of Control,翻译成中文就是“控 ...
- .NET CORE学习笔记系列(2)——依赖注入[7]: .NET Core DI框架[服务注册]
原文https://www.cnblogs.com/artech/p/net-core-di-07.html 包含服务注册信息的IServiceCollection对象最终被用来创建作为DI容器的IS ...
- .NET CORE学习笔记系列(2)——依赖注入[5]: 创建一个简易版的DI框架[下篇]
为了让读者朋友们能够对.NET Core DI框架的实现原理具有一个深刻而认识,我们采用与之类似的设计构架了一个名为Cat的DI框架.在上篇中我们介绍了Cat的基本编程模式,接下来我们就来聊聊Cat的 ...
- .NET CORE学习笔记系列(2)——依赖注入[4]: 创建一个简易版的DI框架[上篇]
原文https://www.cnblogs.com/artech/p/net-core-di-04.html 本系列文章旨在剖析.NET Core的依赖注入框架的实现原理,到目前为止我们通过三篇文章从 ...
随机推荐
- エンジニア死滅シタ世界之学べない学校 [MISSION LEVEL: C]-Python3
答案 # coding: utf-8 # 自分の得意な言語で # Let's チャレンジ!! N=input() w_a=0 w_b=0 gpc_dict={ "gg":0,&qu ...
- windows7 10 windows2008 windws2012 nfs客户端的安装
servermanagercmd.exe -install FS-NFS-Services for windows2008 windows2012 在添加功能角色-添加文件打印服务选择nfs客户端 ...
- Android中为什么主线程不会因为Looper.loop()方法造成阻塞
很多人都对Handler的机制有所了解,如果不是很熟悉的可以看看我 如果看过源码的人都知道,在处理消息的时候使用了Looper.loop()方法,并且在该方法中进入了一个死循环,同时Looper.lo ...
- Android:修改连接到AP端显示的设备名
一.Android系统代码中实现设备名分配 1. \frameworks\base\services\core\java\com\android\server\ConnectivityService. ...
- linux/videodev.h: No such file or directory错误解决方法
sudo apt-get install libv4l-dev* file yum install libv4l-dev* yum install libv4l-dev* 上面错误的问题是两个2.4以 ...
- 遍历List集合删除元素的出现报错
遍历List集合删除元素的出现报错 遍历List集合删除元素的时候会发生索引越界异常或内容遍历不全等问题. 例子: List<String> al = new ArrayList< ...
- 浏览器打印出一段unicode码,汉字无法正常显示
处理办法:http://tool.chinaz.com/tools/unicode.aspx:unicode转中文就可以啦
- redis列表和有序集合
redis中的list数据类型是可以插入重复数据的,有去重的需求的话可以用redis有序集合数据类型 Redis Zadd 命令用于将一个或多个成员元素及其分数值加入到有序集当中. 如果某个成员已经是 ...
- ELK之elasticsearch7版本集群设置
ELK7版本搭建参考:https://www.cnblogs.com/minseo/p/10948632.html node-1已经安装配置好 配置文件如下 [root@salt-test conf. ...
- self-attention详解
编写你自己的 Keras 层 对于简单.无状态的自定义操作,你也许可以通过 layers.core.Lambda 层来实现.但是对于那些包含了可训练权重的自定义层,你应该自己实现这种层. 这是一个 K ...