如何获取ObjectSet 的实体密钥名称?

.net c# entity-framework

我在我的通用存储库中创建了一个通用的ObjectSet<T>

我想得到的是ObjectSet<T>的EntityKey的name ,以便我可以在DataContext.GetObjectByKey使用它。

我已经四处搜索并深入挖掘,但我似乎无法在ObjectSet类中的任何位置找到此值。

一般承认的答案

我刚才看到了一个很好的方法来做到这一点并没有找到一个。我通常最终在某处和其中构建一个GetEntityByKey扩展方法,连接字符串以构建TryGetObjectByKey调用的实体密钥。构建实体密钥的一般想法是这样的:

internal class Program
{
    private static void Main(string[] args)
    {
        var dc = new AdventureWorksLT2008Entities();
        object c;
        dc.TryGetObjectByKey(GetEntityKey(dc.Customers, 23), out c);
        var customer = c as Customer;
        Console.WriteLine(customer.EmailAddress);
    }

    private static EntityKey GetEntityKey<T>(ObjectSet<T> objectSet, object keyValue) where T : class
    {
        var entitySetName = objectSet.Context.DefaultContainerName + "." + objectSet.EntitySet.Name;
        var keyPropertyName = objectSet.EntitySet.ElementType.KeyMembers[0].ToString();
        var entityKey = new EntityKey(entitySetName, new[] {new EntityKeyMember(keyPropertyName, keyValue)});
        return entityKey;
    }
}

你也许可以做类似的事情。为简单起见,此示例假设每个EntityKey都有一个字段 - 对于多个值键,您需要使用ObjectSet<T>.ElementType.KeyMembers执行稍微复杂的操作,并将所有键传递到EntityKey构造函数中。


热门答案

通用:

public class GenericoRepositorio<T> : IGenericoRepositorio<T> where T : class
{
    protected readonly ObjectSet<T> ObjetoSet;
    protected readonly ModeloContainer Contexto;

    public GenericoRepositorio(ModeloContainer contexto)
    {
        Contexto = contexto;
        ObjetoSet = Contexto.CreateObjectSet<T>();
    }

    public T Carregar(int id)
    {
        object objeto;
        Contexto.TryGetObjectByKey(GetEntityKey(ObjetoSet, id), out objeto);
        return (T)objeto;
    }

    private static EntityKey GetEntityKey<T>(ObjectSet<T> objectSet, object keyValue) where T : class
    {
        var entitySetName = objectSet.Context.DefaultContainerName + "." + objectSet.EntitySet.Name;
        var keyPropertyName = objectSet.EntitySet.ElementType.KeyMembers[0].ToString();
        var entityKey = new EntityKey(entitySetName, new[] { new EntityKeyMember(keyPropertyName, keyValue) });
        return entityKey;
    }
}



许可下: CC-BY-SA with attribution
不隶属于 Stack Overflow
这个KB合法吗? 是的,了解原因
许可下: CC-BY-SA with attribution
不隶属于 Stack Overflow
这个KB合法吗? 是的,了解原因