gpt4 book ai didi

c# - WHERE IN 子句

转载 作者:行者123 更新时间:2023-11-30 14:59:41 27 4
gpt4 key购买 nike

我在 MVC3 项目中工作。我浏览了一段时间并尝试了几个示例,但无法正常工作。

我需要从 OrderForm 表中获取记录列表,其 DeptID 在我已经获得的另一个列表中。

我知道我需要使用 Contains() 替换 IN SQL 子句,但我可以阅读的每个示例都以相同的方式执行此操作

.Where(ListOfDepartments.Contains(q.DeptID))

这是我在 Controller 上的方法,显然不起作用:

public ActionResult ValidOrders(string installation, string orderpriority, string stockclass, string validity)
{
int instID = System.Convert.ToInt32(installation);
int orderpriorityID = System.Convert.ToInt32(orderpriority);
int stockclassID = System.Convert.ToInt32(stockclass);
string period = validity;

try
{
var departments = dba.Department
.Where (a => a.InstID == instID);

var valid = dba.OrderForm
.Where(q => q.FormType == 3
&& q.FormStatus == 2
&& q.OrderPriority.OrderPriorityID == orderpriorityID
&& q.StockClassID == stockclassID
&& departments.Contains(q.DeptID));

return View(valid.ToList());
}
catch (Exception)
{
return View("Error");
}
}

我做错了什么?

最佳答案

您需要一个 int 列表,而不是 Department

var departments = dba.Department
.Where (a => a.InstID == instID)
.Select(d => d.Id);//Id is a guess, it maybe another property name
//.ToList();

关于c# - WHERE IN 子句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16438473/

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