我正在使用 MVC5 和纯 ADO.NET 创建一个新项目(就像一个学习练习),我需要创建一个存储库来注册一个模型和几个相关的对象,这些对象也需要同时创建并且这些对象可能需要依次插入其他对象。
我能想到的最简单的解决方案是有一个庞大的方法(在存储库中)接收父对象的实例(其中包含需要插入的所有相关对象)并且还有一个存储过程接收所有相关数据作为表值参数,然后使用单个事务插入所有内容。
虽然这可能看起来是最直接的方法,但我不是它的忠实拥护者,所以我想知道是否有任何方法/常见做法可以用来共享为创建的 SqlConnection 实例父对象与其他相关对象?
我在想也许在相关对象的构造函数中传递 SqlConnection 对象,这样每个存储库只需要处理插入单个对象的逻辑,但我不确定。
编辑
--------------------------------
这是父对象(模型)的存储库,我认为应该实例化 SqlConnection 并启动事务
public class ModelRepository : IModelRepository
{
public int Add(Model entity)
{
using (var conn = new SqlConnection(ConnectionString))
{
conn.Open();
using (var command = conn.CreateCommand())
{
command.Transaction = conn.BeginTransaction(IsolationLevel.ReadCommitted);
command.CommandText = "up_Model_Insert";
command.CommandType = CommandType.StoredProcedure;
command.Parameters.Add(command.CreateParameter("@pName ", entity.Name));
command.Parameters.Add(command.CreateParameter("@pDescription", entity.Description));
//Other parameters...
//Call the repositories of the other objects
//....
//how can I make the other repositories use the same connection and
//transaction as the Model entity?
return Convert.ToInt32(command.ExecuteScalar());
}
}
}
}
问题是我不知道如何让其他存储库使用与“模型”实体相同的连接和事务。
我读过 Ninject 有这个 "object scope" concept ,但我不确定在我的情况下哪个是正确的。
最佳答案
我不确定您为什么要“共享”连接。回到基础,您应该始终将连接封装在 using
block 中(假设您使用 EF)。
你追求的是交易,对吧?我现在脑子里只想到的是:
您可以做的是将插入逻辑包装在 TransactionInfo
类中。这些 TransactionInfo
类可以采用 Action
和存储库作为参数。该操作最终执行通过给定存储库插入单个对象的逻辑(存储库应遵循一些为您提供 CRUD 逻辑的接口(interface))。
当你有多个 TransactionInfo
时,你可以将它们一起发送到某个地方,这样可以执行开始 database transaction 的逻辑,从每个 执行所有给定的
对象并最终执行交易。Actions
TransactionInfo
TransactionInfo
可以有一个像这样的构造函数:
public TransactionInfo(Action action, ICrudRepository repository)
我希望我已经很好地理解了你。共享 SqlConnection
对我来说似乎是错误的。
关于c# - asp.net MVC - 如何通过不同的存储库类共享同一个 SqlConnection 实例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39987558/