如果您在 Entity Framework 4 中为实体创建通用存储库,您将首先查询实体:
public IEnumerable<E> GetEntity()
{
return _container.CreateQuery<E>( ... );
}
在上面的
...
中,我们需要 EntitySetName,它通常是 E
名称的复数形式。然而,它并不总是像添加一个“s”那么容易。例如,如果我们只添加一个“s”,这将起作用。 return _container.CreateQuery<E>( "[" + typeof(E).Name + "s]");
如果我们有一个真实的实体,这将包含我们的 EntitySetName:
E.EntityKey.EntitySetName
仅提供 E 类型时如何获取 EntitySetName?
最佳答案
这很棘手,尤其是当涉及代理时,但有可能。这是我在 Halfpipe 中的做法:
/// <summary>
/// Returns entity set name for a given entity type
/// </summary>
/// <param name="context">An ObjectContext which defines the entity set for entityType. Must be non-null.</param>
/// <param name="entityType">An entity type. Must be non-null and have an entity set defined in the context argument.</param>
/// <exception cref="ArgumentException">If entityType is not an entity or has no entity set defined in context.</exception>
/// <returns>String name of the entity set.</returns>
internal static string GetEntitySetName(this ObjectContext context, Type entityType)
{
if (context == null)
{
throw new ArgumentNullException("context");
}
if (entityType == null)
{
throw new ArgumentNullException("entityType");
}
// when POCO proxies are enabled, "entityType" may be a subtype of the mapped type.
Type nonProxyEntityType = ObjectContext.GetObjectType(entityType);
if (entityType == null)
{
throw new ArgumentException(
string.Format(System.Globalization.CultureInfo.CurrentUICulture,
Halfpipe.Resource.TypeIsNotAnEntity,
entityType.Name));
}
var container = context.MetadataWorkspace.GetEntityContainer(context.DefaultContainerName, System.Data.Metadata.Edm.DataSpace.CSpace);
var result = (from entitySet in container.BaseEntitySets
where entitySet.ElementType.Name.Equals(nonProxyEntityType.Name)
select entitySet.Name).SingleOrDefault();
if (string.IsNullOrEmpty(result))
{
throw new ArgumentException(
string.Format(System.Globalization.CultureInfo.CurrentUICulture,
Halfpipe.Resource.TypeIsNotAnEntity,
entityType.Name));
}
return result;
}
关于c# - Entity Framework 4 : Generic Repository: How do I determine the EntitySetName?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/4168761/