首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在抽象GraphDiff时,如何使用DBContext?

在抽象GraphDiff时,如何使用DBContext?
EN

Stack Overflow用户
提问于 2014-11-17 19:28:24
回答 2查看 371关注 0票数 0

我刚刚了解了GraphDiff,以及它应该如何处理断开连接的实体与存储在数据库中的实体之间的所有差异。

问题是我不知道如何使用GraphDiff,我尝试了文档,但我不太了解它。

我使用抽象的DBContext,通过接口并使用DbSet,以便对它们执行单元测试:

代码语言:javascript
复制
public interface IDbRepositories
{
    IDbSet<Client> ClientsDB { get;}
    AppIdentityDbContext DB { get; }
    IDbSet<Contacts> ContactsDB { get; }
    IDbSet<ExposureResult> ExposureDB { get; }
    IDbSet<OrderMods> OrderModsDB { get; }
    IDbSet<ProductDetails> ProductDetailsDB { get; }

    IDbSet<OrderProcess> OrderProcessDB { get; }

    IDbSet<Order> OrderDB { get; }

    void SaveChanges();
}

这是实现接口的实际类:

代码语言:javascript
复制
public class DbRepositories : IDbRepositories
{
    private AppIdentityDbContext db = new AppIdentityDbContext();

    //Get DB Context. This is done this way, so a Mock can be injected when testing
    public IDbSet<Client> ClientsDB
    {
        get { return db.Clients; }
    }

    public AppIdentityDbContext DB
    {
        get { return db; }
    }

    public IDbSet<Contacts> ContactsDB
    {
        get { return db.Contacts; }
    }

    public IDbSet<ExposureResult> ExposureDB
    {
        get { return db.ExposureTBL; }
    }

    public IDbSet<OrderMods> OrderModsDB
    {
        get { return db.OrderMods; }
    }

    public IDbSet<ProductDetails> ProductDetailsDB
    {
        get { return db.ProductDetailsTBL; }
    }

    public IDbSet<OrderProcess> OrderProcessDB
    {
        get { return db.OrderProcesses; }
    }

    public IDbSet<Order> OrderDB
    {
        get { return db.OrderTBL; }
    }

    public void SaveChanges()
    {
        this.db.SaveChanges();
    }
}

现在,问题就在这里:

代码语言:javascript
复制
public bool SaveOrderChanges(OrderProcess[] Order, int OrderID, int uid)
{
    //2nd Step:
    var ComparableObject = dbs.OrderProcessDB.Where(x => x.OrderID == OrderID).ToList();
    var Objections = dbs.OrderDB.Where(x => x.OrderID == OrderID).FirstOrDefault();
    dbs.DB.UpdateGraph(dbs.OrderDB, m => m.OwnedCollection());
    dbs.SaveChanges();
    return true;
 }

我想告诉您Order参数和我从OrderProcessDB中提取的参数之间的区别。这是一对多的关系。

我不知道如何在这个场景中使用GraphDiff。有什么想法吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-06-20 16:12:46

您可以在接口中公开基本的DbContext对象,但这违反了封装的基本原则。挑战在于UpdateGraph方法是具体DbContext类的静态扩展。这是我的解决方案:

首先是接口:

代码语言:javascript
复制
public interface IMyDbContext
{
    ...

    TEntity UpdateGraph<TEntity>(TEntity entity, Expression<Func<IUpdateConfiguration<TEntity>, object>> mapping = null) where TEntity : class, new();
}

然后是实际的DbContext:

代码语言:javascript
复制
public class MyDbContext : DbContext, IMyDbContext
{
    ...

    public TEntity UpdateGraph<TEntity>(TEntity entity, Expression<Func<IUpdateConfiguration<TEntity>, object>> mapping = null) where TEntity : class, new()
    {
        return ((DbContext)this).UpdateGraph(entity, mapping);
    }
}

最后,在存储库中使用示例:

代码语言:javascript
复制
public class MyRepository : IMyRepository
{
    private readonly IMyDbContext _myDbContext;

    public MyRepository (IMyDbContext myDbContext)
    {
        _myDbContext = myDbContext;
    }

    public async Task<SomeEntity> UpdateSomeEntity(SomeEntity updatedSomeEntity)
    {
        _myDbContext.UpdateGraph(updatedSomeEntity, map => map.OwnedCollection(p => p.SomeChildCollection));
        await _myDbContext.SaveChangesAsync();

        return updatedSomeEntity;
    }
}
票数 0
EN

Stack Overflow用户

发布于 2015-07-03 15:02:46

我意识到这很古老,但我刚刚发现了GraphDiff,希望能帮助其他人寻找。

以下是如何使用GraphDiff:

代码语言:javascript
复制
 db.UpdateGraph(orderToUpdate, map => map
                    .AssociatedCollection(t => t.Products)
                    .OwnedCollection(t => t.PaymentMethods));

这意味着要更新Order对象,并且订单拥有PaymentMethods (意味着它实际上可以删除这些实体),并且与产品实体相关联(这意味着它将从引用表中删除它们)。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26980418

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档