условия на вершине

не написать динамический запрос для Linq, если у меня есть класс Customer, который содержит поля:

string name
string address
int phoneno

Я должен сделать запрос на основе информации, аналогичной

query = string.Empty;

if(!string.IsNullorEmpty(name))
{
   query += "@name = name";
}

if(!string.IsNullorEmpty(address))
{
   query += "@address = address";
}

if(!string.IsNullorEmpty(phoneno))
{
   query += "@phoneno = phoneno";
}

var result = from condition in customer
    where(query)
    select condition;

Редактировать № 1:

элементы меняются во время выполнения, как

private Customer[] GetCustomers(Dictionary<string,string> attributes)
{
   here the attribute may be, name alone, or name and address, or name address and phoneno


      foreach(string field in attributes.key)
      {
           query += field == attributes[,key];

      }

         Customers[] =ExecuteQuery(query);

}

Этот тип запроса поддерживается LINQ?

Изменить № 2:

Привет мук,
Поскольку я новичок в C #, я все еще борюсь, это не работает для меня.

var query = _ConfigFile.ConnectionMasterSection;

for(int i = 0; i < filter.count; i++)
{
    query = result.Where(p => typeof(ConnectionMaster).GetProperty(filter[i].Attribute).Name == filter[i].Value);
}

Это приводит к Пусто, где, как я использовал это

var query = _ConfigFile.ConnectionMasterSection;

//Hard coded
res.Where(q => q.category == filter[0].Value);

И это сработало, как я и ожидал.

Привет Брайан Уоттс,
Я также попробовал ваш код и получил эту ошибку: «Лямбда-параметр не находится в области».

for(int i = 0; i < filter.count; i++)
{
    Field item = filter[i];

    MemberExpression param = Expression.MakeMemberAccess(Expression.Parameter(typeof(Connection), "p"), typeof(Connection).GetProperty(item.Attribute));

    MemberExpression constant = Expression.MakeMemberAccess(Expression.Constant(item), typeof(Field).GetProperty("Value"));
}


try
{
    var myquery = Queryable.Where(coll, Expression.Lambda<Func<Connection, bool>>(
    Expression.Equal(param, constant), Expression.Parameter(typeof(Connection),"p")));
}

В чем здесь ошибка?

Ответы на вопрос(5)

Ваш ответ на вопрос