gpt4 book ai didi

C# LINQ 多选

转载 作者:行者123 更新时间:2023-11-30 17:05:47 26 4
gpt4 key购买 nike

我正在将 Cases 与 Controls 进行匹配,基本上是 Case 列表中的记录,需要具有字符串 m_ctrlno 中指定的匹配数。

到目前为止,我有两个列表,where 子句是正确的,但是我不确定如何使用 SelectMany 来获取匹配 1 个 Case 的 3 个控件。我决定使用 .Take() 函数,但它似乎不起作用。当我在 var 查询上循环时,我没有得到 3 个不同控件的相同情况。

代码如下:

List<CaseSelection> CurrentCaseList = new List<CaseSelection>();
foreach (CaseSelection CurrentCase in m_casesarraylist)
CurrentCaseList.Add(CurrentCase);

List<ControlSelection> CurrentControlList = new List<ControlSelection>();
foreach (ControlSelection CurrentControlRec in ControlList)
CurrentControlList.Add(CurrentControlRec);


var query = CurrentCaseList.SelectMany(
c => CurrentControlList.Where(o => o.pracid == c.pracid && o.sex == c.sex &&
CaseSelectionList.AgeIsInRange(c.yob, o.yob, m_years)),
(c, o) =>
new { o, c }).Take(m_ctrlno);

最佳答案

在您的代码中,您定义了 2 个列表 CurrentCaseList,CurrentControlList 但未定义 CaseSelectionList

获取匹配一个case的3个控件,具体见下面代码:

用于选择 TotalDue 小于 500.00 的所有订单的 SelectMany 方法。

代码如下:

decimal totalDue = 500.00M;
using (AdventureWorksEntities context = new AdventureWorksEntities())
{
ObjectSet<Contact> contacts = context.Contacts;
ObjectSet<SalesOrderHeader> orders = context.SalesOrderHeaders;

var query =
contacts.SelectMany(
contact => orders.Where(order =>
(contact.ContactID == order.Contact.ContactID)
&& order.TotalDue < totalDue)
.Select(order => new
{
ContactID = contact.ContactID,
LastName = contact.LastName,
FirstName = contact.FirstName,
OrderID = order.SalesOrderID,
Total = order.TotalDue
}));

foreach (var smallOrder in query)
{
Console.WriteLine("Contact ID: {0} Name: {1}, {2} Order ID: {3} Total Due: ${4} ",
smallOrder.ContactID, smallOrder.LastName, smallOrder.FirstName,
smallOrder.OrderID, smallOrder.Total);
}
}

关于C# LINQ 多选,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16101778/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com