6

我有一个表单,可以根据他们选择的内容过滤数据。

我正在尝试将 linq 查询彼此附加,以便最终结果是他们在屏幕上选择的结果。

这是我的代码:

private void button_Search_Click(object sender, EventArgs e)
{
  using (var model = new SuburbanPortalEntities())
  {
    var qry = from logs in model.Logs
              select logs;

    Guid corpid;
    if (Guid.TryParse(textBox_CorporationGuid.Text, out corpid))
    {
      qry = from logs in model.Logs
                where logs.CorporationId == corpid
                select logs;
    }

    Guid tokenid;
    if (Guid.TryParse(textBox_TokenId.Text, out tokenid))
    {
      qry = from logs in model.Logs
            where logs.TokenId == tokenid
            orderby logs.LogDateTime descending 
            select logs;
    }

    if (checkBox_DisplayErrors.Checked)
    {
      qry = from logs in model.Logs
            where logs.IsException
            select logs;
    }

    if (checkBox_DisplayWarnings.Checked)
    {
      qry = from logs in model.Logs
            where logs.IsWarning
            select logs;
    }

    dataGridView1.DataSource = qry;


  }
}

我没有运气。最后一个 qry 是我的 datagridview 上显示的内容。

有人可以告诉我我做错了什么吗?

谢谢 !

4

4 回答 4

10

这里发生的是您qry每次都从源数据重新定义。qryIEnumerable<T>相同logs,因此您应该能够像这样替换您的代码:

 var qry = model.Logs;

 if( // Condition )
    qry = qry.Where(x => x.CorporationId == corpId);

 if( // Another condition)
    qry = qry.Where(x => x.IsException);

在此设置结束时,qry将是所有选定Where子句的组合,并且应该只生成您正在寻找的项目。

于 2013-08-09T14:34:39.357 回答
6

您可以使用 linq Concat

qry = qry.Concat(
            from logs in model.Logs
            where logs.CorporationId == corpid
            select logs);

另一方面,您可能希望根据您的条件创建查询以选择适当的结果,因此您将查询您的数据源一次。

于 2013-08-09T14:32:30.617 回答
0

我可以推荐在LinqKit中使用 Predicate Builder 函数。您可以使用 And 和 Or 方法附加其他搜索参数。

我正是为了这个目的而使用它并且工作得非常好。

于 2013-08-09T14:33:58.293 回答
0

尝试使用 Concat:

private void button_Search_Click(object sender, EventArgs e)
{
  using (var model = new SuburbanPortalEntities())
  {
    var qry = (from logs in model.Logs
              select logs).ToList();

Guid corpid;
if (Guid.TryParse(textBox_CorporationGuid.Text, out corpid))
{
  qry.Concat((from logs in model.Logs
            where logs.CorporationId == corpid
            select logs).ToList());
}

Guid tokenid;
if (Guid.TryParse(textBox_TokenId.Text, out tokenid))
{
  qry.Concat(from logs in model.Logs
        where logs.TokenId == tokenid
        orderby logs.LogDateTime descending 
        select logs).ToList());
}

if (checkBox_DisplayErrors.Checked)
{
  qry.Concat((from logs in model.Logs
        where logs.IsException
        select logs).ToList());
}

if (checkBox_DisplayWarnings.Checked)
{
  qry.Concat((from logs in model.Logs
        where logs.IsWarning
        select logs).ToList());
}

dataGridView1.DataSource = qry;

} }

于 2013-08-09T14:37:42.047 回答