c# - asp.net MVC - 如何通过不同的存储库类共享同一个 SqlConnection 实例

标签 c# asp.net-mvc dependency-injection asp.net-mvc-5 repository-pattern

我正在使用 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/

相关文章:

c# - 如何获得日期差异

c# - 这个循环可以写得更简洁吗?

dependency-injection - 无法从组合函数创建 View 模型

c# - 注入(inject) IOptions<> 的实例

php - Laravel 处女 : Inject a Model In Controller as Dependency

c# - C# 中的 slider 缩放不正确

c# - Microsoft.VisualStudio.Profiler.dll 在哪里?

asp.net-mvc - 即使设置了CustomError ="On",自定义错误页面也不会显示

javascript - ViewData编译错误: BC30203: Identifier expected

asp.net-mvc - MVC4 Ajax 表单 URL