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的依赖注入框架的实现原理,到目前为止我们通过三篇文章从 ...
随机推荐
- 2018-2019 20175234 实验三《敏捷开发与XP实践》实验报告
目录 2018-2019 20175234 实验三<敏捷开发与XP实践>实验报告 实验内容 实验中的问题 码云链接 参考资料 2018-2019 20175234 实验三<敏捷开发与 ...
- 服务器(Linux)上运行python总结
跑实验换了几次服务器了,每次遇到相似问题都要重新百度,而且每次百度搜索出的顺序都不一样,又得重新找半天,这次把遇到的问题都总结一下. 1.准备 PuTTY和FileZilla FileZilla使用F ...
- Java-JUC(零):Java:现有线程T1/T2/T3,如何确保T1执行完成之后执行T2,T3在T2执行完成之后执行。
要实现多个线程执行完成先后,就要知道如何实现线程之间的等待,java线程等待实现是join.java的jdk中join方法实现如下: public final synchronized void jo ...
- github又提交不了代码了..... X_X
如下: 我们使用git提交代码过程中,突然就登录不上了 原因是 用户名被更改了:git@gitlab.0easy.com 是你的用户名 造成的原因是: 我们clone代码过程中选择了SSH的地址 解决 ...
- LiquiBase实战总结
LiquiBase概述 Liquibase是一个用于跟踪.管理和应用数据库变化的开源的数据库重构工具.它将所有数据库的变化(包括结构和数据)都保存在XML文件中,便于版本控制. Liquibase具备 ...
- python 设计模式之访问者模式
写在前面 设计模式是经过总结.优化的,对我们经常会碰到的一些编程问题的可重用解决方案.一个设计模式并不像一个类或一个库那样能够直接作用于我们的代码.反之,设计模式更为高级,它是一种必须在特定情形下实现 ...
- angular 中的[ngClass]、[ngStyle]
<div style="text-align:center"> <h1> Welcome to {{ title }}! </h1> </ ...
- JDK目录详解
bin目录: 该目录用于存放一些可执行程序. 如javac.exe(java编译器).java.exe(java运行工具),jar.exe(打包工具)和* javadoc.exe(文档生成工具)等. ...
- django模型多对多调用
对于如下的模型: from django.db import models # Create your models here. class Student(models.Model): name = ...
- DN创建
1. 参考采购订单创建DN : BAPI_OUTB_DELIVERY_CREATE_STO FUNCTION zmmfm0202. *"--------------------------- ...