Shouldn't I be able to get the EntityKey object using the complex property method or property method for the DbEntityEntry. I couldn't find any examples MSDN, but I presume that this is possible in Entity Framework 5. I Will not know the name of the entity key or entity as I am using a generic repository interface.
可以将文章内容翻译成中文,广告屏蔽插件可能会导致该功能失效(如失效,请关闭广告屏蔽插件后再试):
问题:
回答1:
If you have a DbEntityEntry
object you get the EntityKey
by first finding the wrapped ObjectContext
:
var oc = ((IObjectContextAdapter)dbContext).ObjectContext;
Then you can find the entity key by
oc.ObjectStateManager.GetObjectStateEntry(dbEntityEntryObject.Entity)
.EntityKey
EDIT
I created two extension methods that get you close to what you want:
public static EntityKey GetEntityKey<T>(this DbContext context, T entity)
where T : class
{
var oc = ((IObjectContextAdapter)context).ObjectContext;
ObjectStateEntry ose;
if (null != entity && oc.ObjectStateManager
.TryGetObjectStateEntry(entity, out ose))
{
return ose.EntityKey;
}
return null;
}
public static EntityKey GetEntityKey<T>( this DbContext context
, DbEntityEntry<T> dbEntityEntry)
where T : class
{
if (dbEntityEntry != null)
{
return GetEntityKey(context, dbEntityEntry.Entity);
}
return null;
}
Now you can do
var entityKey = dbContext.GetEntityKey(entity);
or
var entityKey = dbContext.GetEntityKey(dbEntityEntryObject);
The runtime will pick the right overload.
Note that the syntax that you proposed (dbEntityEntryObject.Property<EntityKey>()
) can't work when the entity has a composite key. You have to get the EntityKey
from the entity itself.