- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我无法理解工作单元的事务概念。我使用如下代码:工作类单元:
public class UnitOfWork : IDisposable
{
private readonly DbContext _context;
private bool disposed = false;
public UnitOfWork()
{
_context = new ResultsContext();
}
public IRepository<T> GetRepository<T>() where T : class
{
return new Repository<T>(_context);
}
public virtual void Dispose(bool disposing)
{
if (!disposed)
{
if (disposing)
{
_context.Dispose();
}
}
disposed = true;
}
public void Dispose()
{
Dispose(true);
GC.SuppressFinalize(this);
}
public Study GetStudyWithAll(string studyUid)
{
ResultsContext context = _context as ResultsContext;
return context.Studies.Where(c => c.StudyUid == studyUid)
.Include(s => s.Tasks.Select(t => t.Plugins))
.Include(s => s.Findings)
.Include(s => s.Patient).FirstOrDefault();
}
public void SaveChanges()
{
if (_context != null)
{
bool saved = false;
do
{
try
{
_context.SaveChanges();
saved = true;
}
catch (DbUpdateException ex)
{
// Get the current entity values and the values in the database
var entry = ex.Entries.Single();
//var currentValues = entry.CurrentValues;
switch (entry.State)
{
case System.Data.EntityState.Added:
// added on client, non in store - store wins
entry.State = System.Data.EntityState.Modified;
break;
case System.Data.EntityState.Deleted:
//deleted on client, modified in store
entry.Reload();
entry.State = System.Data.EntityState.Deleted;
break;
case System.Data.EntityState.Modified:
DbPropertyValues currentValues = entry.CurrentValues.Clone();
//Modified on client, Modified in store
entry.Reload();
entry.CurrentValues.SetValues(currentValues);
break;
default:
//For good luck
entry.Reload();
break;
}
}
catch (System.Data.Entity.Validation.DbEntityValidationException dbEx)
{
Exception raise = dbEx;
foreach (var validationErrors in dbEx.EntityValidationErrors)
{
foreach (var validationError in validationErrors.ValidationErrors)
{
string message = string.Format("{0}:{1}",
validationErrors.Entry.Entity.ToString(),
validationError.ErrorMessage);
// raise a new exception nesting
// the current instance as InnerException
raise = new InvalidOperationException(message, raise);
}
}
throw raise;
}
} while (!saved);
}
}
public DbContext Context
{
get { return _context; }
}
}
我的使用方式:
using (var uow = new UnitOfWork())
{
//////some stuff///
uow.SaveChanges();
}
问题是:工作单元上下文等于事务,还是我需要添加:
using (TransactionScope transaction = new TransactionScope())
围绕它。
我知道 saveChanges 是用事务包裹的,但我不知道的是:整个上下文是否包裹在事务中。我的意思是,我可以确定我读取的数据(不是保存或更新)在上下文的生命周期内没有改变吗?
最佳答案
您的工作单元实现使用单个 DbContext
和对 .SaveChanges()
的单个调用。这本身保证了所有工作都在一个简单的事务中完成。参见,例如:
In all versions of Entity Framework, whenever you execute SaveChanges() to insert, update or delete on the database the framework will wrap that operation in a transaction. This transaction lasts only long enough to execute the operation and then completes. When you execute another such operation a new transaction is started.
如果涉及多个 .SaveChanges()
或什至多个不同的 DbContext
实例,您只需要使用 TransactionScope
(注意在后一种情况它甚至可以触发分布式事务,这取决于正在启动的 MSDTC 服务)。
我添加这条注释是因为评论:为了避免锁定数据库,EF 使用一种称为乐观并发 的机制,它基本上是在保存更改时检查自读取以来没有任何更改。有关详细信息,请参阅这两个链接:
自 EF6 以来,有多种方法可以使用所需的隔离级别启动您自己的“经典”事务。但这通常涉及锁定数据库的一部分,这会对应用程序性能产生有害影响。在大多数情况下,使用乐观并发要好得多。您会发现并发异常抛出的情况非常少,并且如链接中所述,它们可以得到处理。或者您可以将存储过程用于特定任务,例如减少在拥挤的电子商务网站上购买的产品的 UnitsInStock
。也就是说,不是读取单位数量、减少它并保存更改,而是使用修改 protected 事务中的库存的存储过程或涉及隐式事务的 UPDATE
查询。
关于c# - 工作单元设计模式中的事务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34609038/
我想做的是让 JTextPane 在 JPanel 中占用尽可能多的空间。对于我使用的 UpdateInfoPanel: public class UpdateInfoPanel extends JP
我在 JPanel 中有一个 JTextArea,我想将其与 JScrollPane 一起使用。我正在使用 GridBagLayout。当我运行它时,框架似乎为 JScrollPane 腾出了空间,但
我想在 xcode 中实现以下功能。 我有一个 View Controller 。在这个 UIViewController 中,我有一个 UITabBar。它们下面是一个 UIView。将 UITab
有谁知道Firebird 2.5有没有类似于SQL中“STUFF”函数的功能? 我有一个包含父用户记录的表,另一个表包含与父相关的子用户记录。我希望能够提取用户拥有的“ROLES”的逗号分隔字符串,而
我想使用 JSON 作为 mirth channel 的输入和输出,例如详细信息保存在数据库中或创建 HL7 消息。 简而言之,输入为 JSON 解析它并输出为任何格式。 最佳答案 var objec
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个以前可能被问过的问题,但我很难找到正确的描述。我希望有人能帮助我。 在下面的代码中,我设置了varprice,我想添加javascript变量accu_id以通过rails在我的数据库中查找记
我有一个简单的 SVG 文件,在 Firefox 中可以正常查看 - 它的一些包装文本使用 foreignObject 包含一些 HTML - 文本包装在 div 中:
所以我正在为学校编写一个 Ruby 程序,如果某个值是 1 或 3,则将 bool 值更改为 true,如果是 0 或 2,则更改为 false。由于我有 Java 背景,所以我认为这段代码应该有效:
我做了什么: 我在这些账户之间创建了 VPC 对等连接 互联网网关也连接到每个 VPC 还配置了路由表(以允许来自双方的流量) 情况1: 当这两个 VPC 在同一个账户中时,我成功测试了从另一个 La
我有一个名为 contacts 的表: user_id contact_id 10294 10295 10294 10293 10293 10294 102
我正在使用 Magento 中的新模板。为避免重复代码,我想为每个产品预览使用相同的子模板。 特别是我做了这样一个展示: $products = Mage::getModel('catalog/pro
“for”是否总是检查协议(protocol)中定义的每个函数中第一个参数的类型? 编辑(改写): 当协议(protocol)方法只有一个参数时,根据该单个参数的类型(直接或任意)找到实现。当协议(p
我想从我的 PHP 代码中调用 JavaScript 函数。我通过使用以下方法实现了这一点: echo ' drawChart($id); '; 这工作正常,但我想从我的 PHP 代码中获取数据,我使
这个问题已经有答案了: Event binding on dynamically created elements? (23 个回答) 已关闭 5 年前。 我有一个动态表单,我想在其中附加一些其他 h
我正在尝试找到一种解决方案,以在 componentDidMount 中的映射项上使用 setState。 我正在使用 GraphQL连同 Gatsby返回许多 data 项目,但要求在特定的 pat
我在 ScrollView 中有一个 View 。只要用户按住该 View ,我想每 80 毫秒调用一次方法。这是我已经实现的: final Runnable vibrate = new Runnab
我用 jni 开发了一个 android 应用程序。我在 GetStringUTFChars 的 dvmDecodeIndirectRef 中得到了一个 dvmabort。我只中止了一次。 为什么会这
当我到达我的 Activity 时,我调用 FragmentPagerAdapter 来处理我的不同选项卡。在我的一个选项卡中,我想显示一个 RecyclerView,但他从未出现过,有了断点,我看到
当我按下 Activity 中的按钮时,会弹出一个 DialogFragment。在对话框 fragment 中,有一个看起来像普通 ListView 的 RecyclerView。 我想要的行为是当
我是一名优秀的程序员,十分优秀!