Comment trouver la longueur maximale du champ dans Entity Framework .NET 4?
-
23-09-2019 - |
Question
Selon cette question , il n'y a pas moyen intégré dans EF v1 pour déterminer la longueur d'un champ. Est-il possible de le faire dans le Entity Framework intégré qui est livré avec .NET 4, le cas échéant - comment?
La solution
Il n'y a pas de nouvelle façon d'accéder à la longueur d'une propriété dans EF 4.0. Il vous reste à marcher sur les métadonnées -. Comme le montre dans la réponse acceptée sur la question que vous faites référence
Autres conseils
Cela agit:
using System;
using System.Data.Objects;
using System.Data.Objects.DataClasses;
using System.Data.Metadata.Edm;
using System.Linq;
using System.Linq.Expressions;
namespace EfWidgets
{
public class EntityWidgets
{
public static int GetMaxLength<TEntity>(ObjectContext oc, Expression<Func<TEntity, string>> property)
where TEntity : EntityObject
{
var test = oc.MetadataWorkspace.GetItems(DataSpace.CSpace);
if (test == null)
return -1;
Type entType = typeof(TEntity);
string propertyName = ((MemberExpression)property.Body).Member.Name;
var q = test
.Where(m => m.BuiltInTypeKind == BuiltInTypeKind.EntityType)
.SelectMany(meta => ((EntityType)meta).Properties
.Where(p => p.Name == propertyName && p.TypeUsage.EdmType.Name == "String"));
var queryResult = q.Where(p =>
{
var match = p.DeclaringType.Name == entType.Name;
if (!match)
match = entType.Name == p.DeclaringType.Name;
return match;
})
.Select(sel => sel.TypeUsage.Facets["MaxLength"].Value)
.ToList();
if (queryResult.Any())
{
int result = Convert.ToInt32(queryResult.First());
return result;
}
return -1;
}
}
}
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow