Entity Framework, предоставляющий имена столбцов в виде строковых переменных - PullRequest
12 голосов
/ 21 октября 2011

Я ищу способ получить что-то вроде этого:

string _col1 = "first name";
string _name;
var query = from c in ctx.Customers select c;
_name = query.FirstOrDefault().[_name];

Насколько я вижу, я могу получить только строго типизированные имена полей, но я бы хотел предоставить их как строковые переменные.

Ответы [ 3 ]

20 голосов
/ 21 октября 2011

Я не уверен, что EF предоставляет вам способ получить значение свойства на основе строкового имени свойства, но вы можете использовать отражение.

string name = typeof(Customer)
    .GetProperty("first name")
    .GetValue(query.First(), null) as string;

Я предполагаю, что класс EF, с которым вы имеете дело, называется Customer.

5 голосов
/ 21 октября 2011

Вы должны использовать отражение для этого.Если вы пытаетесь фильтровать по динамически выбранному столбцу, вы можете попробовать что-то вроде этого:

string propertyName
string keyword

ParameterExpression parameter = Expression.Parameter(typeof(YourType), "x");
Expression property = Expression.Property(parameter, propertyName);
Expression target = Expression.Constant(keyword);
Expression containsMethod = Expression.Call(property, "Contains", null, target);
Expression<Func<YourType, bool>> lambda =
   Expression.Lambda<Func<YourType, bool>>(containsMethod, parameter);

var companies = repository.AsQueryable().Where(lambda);

Я пытаюсь выбрать конкретный столбец, тогда вы можете использовать тот же принцип для генерациивыражение лямба и использование его в выборе (минус условие)

var companies = repository.AsQueryable().Where(whatever).Select(lambda);
1 голос
/ 12 апреля 2012

По какой-то причине у меня это не сработает.

Это мое аналогичное рабочее решение:

string name = null;

// Select the PropertyInfo of the column.
PropertyInfo propertyInfo = query.First().GetType().GetProperty("first name");

if (propertyInfo != null)
{
  try
  {
    // Select the content of the column.
    name = pi.GetValue(query.First(), null).ToString();
  }
  catch (Exception)
  { 
    // Continue with null-string.
  }

}

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...