首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >检查表是否包含列表中的值

检查表是否包含列表中的值
EN

Stack Overflow用户
提问于 2016-01-11 03:58:40
回答 4查看 1.2K关注 0票数 2

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

代码语言:javascript
复制
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子句?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2016-01-11 16:14:09

LINQ Oneliner

代码语言:javascript
复制
List<string> TheListParameter = new List<string>{"string1", "string2", "string3"};

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

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

以这个例子为例。

代码语言:javascript
复制
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()

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

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

代码语言:javascript
复制
var a = myDc.someEntity.Where(a=> a.someDate.DayOfYear == 123); 
// Fails as DayOfYear cannot be translated to  SQL expression

在这里,您需要在过滤数据之前对其进行投影,遗憾的是,需要加载所有数据才能完成此操作

代码语言:javascript
复制
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()

票数 1
EN

Stack Overflow用户

发布于 2016-01-11 04:02:54

请尝试以下操作

代码语言:javascript
复制
  List<string> TheListParameter = new List<string>{"string1", "string2", "string3"};

  var TheOutput = (from t in MyDC.SomeTable
                   where TheListParameter.Any(e => e == t.SomeColumn)
                   select t.SomeColumn).ToList();
票数 1
EN

Stack Overflow用户

发布于 2016-01-11 04:10:24

根据ContainDocumentationContains的参数可能是string,而不是一个字符串列表,所以应该是这样的:

代码语言:javascript
复制
List<string> TheListParameter = new List<string> {"string1", "string2", "string3"};

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

或者,如果您想返回一个布尔结果,如果MyDC.SomeTable.SomeColumn包含TheListParameter的一个字符串,您可以尝试如下所示:

代码语言:javascript
复制
bool hasSameElements = MyDC.SomeTable.ToList()
                      .Select(c => c.SomeColumn)
                      .Intersect(TheListParameter).Any(); //True or False
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34710141

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档