转换foreach和if到linq查询

时间:2016-09-26 09:03:18

标签: c# linq linq-query-syntax

  foreach (SchemaInfo db in SourceSchemaInfos)
            {
                foreach (SchemaInfo table in db.SchemaInfos)
                {
                    foreach (SchemaInfo tablelist in table.SchemaInfos)
                    {
                        for (int i = 0; i < SelectedTables.Count; i++)
                        {
                            if (tablelist.Key == SelectedTables[i].Key)
                            {
                                foreach (SchemaInfo _tableschema in tablelist.SchemaInfos)
                                {
                                    _tableschema.IsSelected = true;
                                }
                            }
                        }
                    }
                }
            }

我试图将上面的foreach循环转换为linq查询,如下所示。

  SourceSchemaInfos.ForEach(Database =>Database.SchemaInfos.ForEach(items => items.SchemaInfos.ForEach(tables => tables.SchemaInfos.Where(tables.Key == SelectedTables.ForEach(l => l.Key)).ForEach(m => m.IsSelected = true))));

但是它给我带来了以下错误@ l.Key

CS0201  Only assignment, call, increment, decrement, and new object expressions can be used as a statement

`

2 个答案:

答案 0 :(得分:2)

尝试以下代码。我认为这是LINQ您的查询的正确转换

 foreach (var _tableschema in 
            (from db in SourceSchemaInfos from table in db.SchemaInfos from tablelist in table.SchemaInfos 
             select tablelist)
            .SelectMany(tablelist => SelectedTables.Where(t => tablelist.Key == t.Key)
                .SelectMany(t => tablelist.SchemaInfos)
                ))
        {
            _tableschema.IsSelected = true;
        }

答案 1 :(得分:2)

var schemaInfos = from db in SourceSchemaInfos
                  from table in db.SchemaInfos
                  from tableList in table.SchemaInfos
                  from selectedTable in SelectedTables
                  where tableList.Key == selectedTable.Key
                  select tableList.SchemaInfos;

foreach(var tableSchema in schemaInfos)
{
    tableSchema.IsSelected = true;
}