gpt4 book ai didi

c# - 检查表是否包含列表中的值

转载 作者:行者123 更新时间:2023-11-30 21:52:31 25 4
gpt4 key购买 nike

我有一个字符串参数列表,我想编写一个查询,返回一个字符串列表,其中包含表中存在的参数列表的值。我有以下查询但无法获取 where 子句:

List<string> TheListParameter = new List<string>{"string1", "string2", "string3"};

var TheOutput = (from t in MyDC.SomeTable
where t.SomeColumn.Contains(TheListParameter)
select t.SomeColumn).ToList();

如何为该搜索查询编写 where 子句?

最佳答案

LINQ 联机

List<string> TheListParameter = new List<string>{"string1", "string2", "string3"};

var foundElements = MyDC.SomeTable.Where(a=> TheListParameter.Contains(a.SomeColumn)).Select(a=> a.SomeColumn);

为什么每个人都抛出 ToList() 在我身边。这完全取决于您是否需要实现所有数据。

举个例子。

using(dbCtx myDc = new dbCtx()){
var unrealizedList = myDc.someEntity;
var realizedList = myDc.someEntity.ToList();

var a1 = unrealizedList.First() //Works
var b1 = realizedList.First() //Works
}
var a2 = unrealizedList.First() //Fails as unrealizedList is empty (not loaded and context is gone)
var b2 = realizedList.First() //Works because the realizedList was loaded completely by the ToList()

现在,如果您有一个全局或本地(不是 using)Ctx,那么您可能永远不需要 ToList(),尽管使用 using 是一种干净利落的获取方式控制您的上下文,当您有多个上下文在彼此上工作时,这可能是一个问题。

ToList() 查询中的一个小指针。

var a = myDc.someEntity.Where(a=> a.someDate.DayOfYear == 123); 
// Fails as DayOfYear cannot be translated to SQL expression

在这里你需要在过滤数据之前投影数据,遗憾的是需要加载所有数据才能这样做

var a = myDc.someEntity.ToList().Where(a=> a.someDate.DayOfYear == 123); 
// Works as the data no longer is filtered in SQL (the SQL is "Select * from someEntity")

因此,如果可以,请在 ToList() 之前执行过滤,以限制从数据库中提取的数据量。

相反,如果 ToList() 您可以使用其他列表以及 ToArray()

关于c# - 检查表是否包含列表中的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34710141/

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