如何获得工具表中持续的名称的收集c#linq

发布于 2025-02-08 11:56:29 字数 1061 浏览 2 评论 0原文

我有一个带有工具和工人的摘要表。因此,我无法处理的任务是如何在不涉及的摘要表中获取最后的工具计数。我想这就是这样,

var res = context.ToolsSummaryTable.Include(t => t.Tool).Include(t => t.Worker)
          where(t.Tool.Name.Count() > t.Tool.Quantity);

请帮忙!

数据

工作人员工具ID
12
23
32
12

工具表数据

名称数量
螺丝刀2
悍马3
扳手171
管子扳手2

表数据

名称名称名称lastname
andrewGreekman
gordongordon
摘要表gordon
Wingman工人

I have a summary table with tools and workers. So task with i can't handle is how to get count of lasts tools in the summary table that are not involved. I guess it would be like this

var res = context.ToolsSummaryTable.Include(t => t.Tool).Include(t => t.Worker)
          where(t.Tool.Name.Count() > t.Tool.Quantity);

Please Help!

Summary table Data

WorkerIDToolID
12
23
32
12

Tools table data

NameQuantity
Screwdriver2
Hummer3
Wrench 171
Pipe wrench2

Workers table data

FirstNameLastName
AndrewGreekman
GordonWingman
SamPeacekeeper
AntonyScout

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

狠疯拽 2025-02-15 11:56:29

您需要一个左外连接。
左外连接是:“从G.Defaultifempty()的Tuusednone中”
请参阅下面的代码

using System;
using System.Linq;
using System.Text;
using System.Collections;
using System.Collections.Generic;

namespace ConsoleApp2
{
    class Program
    {
        static void Main(string[] args)
        {
            Context context = new Context()
            {
                Sumary = new List<Summary>()
               {
                   new Summary() {WorkerId = 1, ToolId = 2 },
                   new Summary() {WorkerId = 2, ToolId = 3 },
                   new Summary() {WorkerId = 3, ToolId = 2 },
                   new Summary() {WorkerId = 1, ToolId = 2 }
               },
                Tools = new List<Tools>()
               {
                   new Tools() { ToolId = 1, Name = "Screwdriver", Quantity = 2},
                   new Tools() { ToolId = 2, Name = "Hummer", Quantity = 3},
                   new Tools() { ToolId = 3, Name = "Wrench 17", Quantity = 1},
                   new Tools() { ToolId = 4, Name = "Pipe Wrench", Quantity = 2}
               },
                Workers = new List<Workers>()
               {
                   new Workers() { WorkerId = 1, FirstName = "Andrew", LastName = "Greekman"},
                   new Workers() { WorkerId = 2, FirstName = "Gordon", LastName = "Wingman"},
                   new Workers() { WorkerId = 3, FirstName = "Sam", LastName = "Peacekeeper"},
                   new Workers() { WorkerId = 4, FirstName = "Antony", LastName = "Scout"}
               }
            };
            var toolsUsed = context.Sumary.GroupBy(x => x.ToolId)
                .Select(x => new { toolId = x.Key, quantityUsed = x.Count() });
            var toolsRemaining = (from t in context.Tools 
                                  join tu in toolsUsed on t.ToolId equals tu.toolId into g
                                  from tuUsedNone in g.DefaultIfEmpty()
                                  select (new { Name = t.Name, toolsRemaining = (tuUsedNone == null) ? t.Quantity : t.Quantity - tuUsedNone.quantityUsed }))
                .ToList();
               
        }
 
    }
 
    public class Context
    {
        public List<Summary> Sumary { get; set; }
        public List<Tools> Tools { get; set; }
        public List<Workers> Workers { get; set; }
    }
    public class Summary
    {
        public int WorkerId { get; set; }
        public int ToolId { get; set; }
    }
    public class Tools
    {
        public int ToolId { get; set; }
        public string Name { get; set; }
        public int Quantity { get; set; }
    }
    public class Workers
    {
        public int WorkerId { get; set; }
        public string FirstName { get; set; }
        public string LastName { get; set; }
    }
}

You need a left outer join.
The left outer join is : "from tuUsedNone in g.DefaultIfEmpty()"
See code below

using System;
using System.Linq;
using System.Text;
using System.Collections;
using System.Collections.Generic;

namespace ConsoleApp2
{
    class Program
    {
        static void Main(string[] args)
        {
            Context context = new Context()
            {
                Sumary = new List<Summary>()
               {
                   new Summary() {WorkerId = 1, ToolId = 2 },
                   new Summary() {WorkerId = 2, ToolId = 3 },
                   new Summary() {WorkerId = 3, ToolId = 2 },
                   new Summary() {WorkerId = 1, ToolId = 2 }
               },
                Tools = new List<Tools>()
               {
                   new Tools() { ToolId = 1, Name = "Screwdriver", Quantity = 2},
                   new Tools() { ToolId = 2, Name = "Hummer", Quantity = 3},
                   new Tools() { ToolId = 3, Name = "Wrench 17", Quantity = 1},
                   new Tools() { ToolId = 4, Name = "Pipe Wrench", Quantity = 2}
               },
                Workers = new List<Workers>()
               {
                   new Workers() { WorkerId = 1, FirstName = "Andrew", LastName = "Greekman"},
                   new Workers() { WorkerId = 2, FirstName = "Gordon", LastName = "Wingman"},
                   new Workers() { WorkerId = 3, FirstName = "Sam", LastName = "Peacekeeper"},
                   new Workers() { WorkerId = 4, FirstName = "Antony", LastName = "Scout"}
               }
            };
            var toolsUsed = context.Sumary.GroupBy(x => x.ToolId)
                .Select(x => new { toolId = x.Key, quantityUsed = x.Count() });
            var toolsRemaining = (from t in context.Tools 
                                  join tu in toolsUsed on t.ToolId equals tu.toolId into g
                                  from tuUsedNone in g.DefaultIfEmpty()
                                  select (new { Name = t.Name, toolsRemaining = (tuUsedNone == null) ? t.Quantity : t.Quantity - tuUsedNone.quantityUsed }))
                .ToList();
               
        }
 
    }
 
    public class Context
    {
        public List<Summary> Sumary { get; set; }
        public List<Tools> Tools { get; set; }
        public List<Workers> Workers { get; set; }
    }
    public class Summary
    {
        public int WorkerId { get; set; }
        public int ToolId { get; set; }
    }
    public class Tools
    {
        public int ToolId { get; set; }
        public string Name { get; set; }
        public int Quantity { get; set; }
    }
    public class Workers
    {
        public int WorkerId { get; set; }
        public string FirstName { get; set; }
        public string LastName { get; set; }
    }
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文