加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 我想将这个foreach循环转换为LINQ语句

发布时间:2020-12-16 02:02:37 所属栏目:百科 来源:网络整理
导读:无论如何我对 linq都不是很了不起,但我对这类问题通常没有任何问题.我想将此foreach语句转换为LINQ语句: var existingKeys = new Listint();foreach (var taskKey in request.Keys) { existingKeys.AddRange(_context.WebTaskGroups .Where(x = x.TaskGroup
无论如何我对 linq都不是很了不起,但我对这类问题通常没有任何问题.我想将此foreach语句转换为LINQ语句:

var existingKeys = new List<int>();
foreach (var taskKey in request.Keys)
        {
             existingKeys.AddRange(_context.WebTaskGroups
                 .Where(x => x.TaskGroupNameKey == key && x.TaskKey == taskKey)
                 .Select(x => x.TaskGroupNameKey));
        }

我以为这样做会:

var existingKeys = request.Keys.ForEach(taskKey => _context.WebTaskGroups
        .Where(x => x.TaskGroupNameKey == key && x.TaskKey == taskKey)
        .Select(x => x.TaskGroupNameKey));

这显然是一个无法列出的空白……
这个:

var existingKeys = request.Keys.Select(taskKey => 
            _context.WebTaskGroups
            .Where(x => x.TaskGroupNameKey == key && x.TaskKey == taskKey)
            .Select(keys => keys.TaskGroupNameKey));

给我一个“IEnumerable< IQueryable< int>>.那么我在这里失踪的秘诀是什么?

解决方法

您不应该首先执行N个数据库查询.使用LINQ来执行那些N个查询而不是foreach循环并不能解决这个核心问题.

您需要重新概念化查询,以便只有一个查询可以获取所需的所有数据.在这种情况下,这意味着获取与您的密钥集合匹配的所有项目,而不是尝试匹配单个密钥,然后执行N个查询.

var requestedKeys = request.Keys;
var existingKeys = _context.WebTaskGroups
                 .Where(x => x.TaskGroupNameKey == key && 
                     requestedKeys.Contains(x.TaskKey))
                 .Select(x => x.TaskGroupNameKey))
                 .ToList();

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读