Linq to Sql DB Object to Domain Object的映射和性能

时间:2010-03-09 23:18:26

标签: c# sql-server asp.net-mvc linq-to-sql delayed-execution

我在尝试进行LINQ to SQL查询和映射到我的域对象DRY时遇到问题,而不会产生多次往返db的成本。给出这个例子:

var query1 = from x in db.DBProducts
            select new MyProduct
            {
                Id = x.ProductId,
                Name = x.ProductName,
                Details = new MyProductDetail
                {
                    Id = x.DBProductDetail.ProductDetailId,
                    Description = x.DBProductDetail.ProductDetailDescription
                }
            }

查询将向DB进行一次往返。大!但是,我看到的问题是,最终,我还将拥有一个'GetProductDetails'方法,该方法还需要执行一些SAME“数据对象 - >域对象”映射,与上面的方法非常相似。 / p>

为了减轻一些映射,我认为扩展部分数据对象类为我做映射可能是一个很酷的主意,如下所示:

public partial class DBProduct
{
    MyProduct ToDomainObject()
    {
        return new MyProduct
        {
            Id = this.ProductId,
            Name = this.ProductName,
            Details = this.DBProductDetails.ToDomainObject()
        };
    }
}

public partial class DBProductDetail
{
    MyProductDetail ToDomainObject()
    {
        return new MyProductDetail
        {
            Id = this.ProductDetailId,
            Description = this.ProductDetailDescription
        };
    }
}

尼斯!现在,我可以简单地重写query1,如下所示:

var query1 = from x in db.DBProducts
            select x.ToDomainObject();

这使代码更干燥,更易读。此外,需要执行相同类型映射的其他查询可以简单地使用ToDomainObject()方法进行映射。它有效,但需要付出代价。在通过Profiler观看时,第一个查询将调用db ONCE,并在必要时连接表。第二个查询没有正确连接,因此多次调用DB。有没有办法完成我正在尝试做的事情:重构LINQ to SQL查询,以便映射到域对象是DRY(没有代码重复)?

1 个答案:

答案 0 :(得分:1)

使用AutoMapper。一旦你尝试过,你就不可能看到这样的代码:

new MyProduct
{
    Id = x.ProductId,
    Name = x.ProductName,
    Details = new MyProductDetail
    {
        Id = x.DBProductDetail.ProductDetailId,
        Description = x.DBProductDetail.ProductDetailDescription
    }
}