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

时间:2016-01-10 19:58:40

标签: c# linq linq-to-sql

我有一个字符串的参数列表,我想编写一个查询,该查询返回一个字符串列表,其中包含表中存在的参数列表的值。我有以下查询,但我无法获得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子句?

感谢。

4 个答案:

答案 0 :(得分:1)

尝试以下

  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 :(得分:1)

基于Contains Documentationstring的参数可能是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包含bool hasSameElements = MyDC.SomeTable.ToList() .Select(c => c.SomeColumn) .Intersect(TheListParameter).Any(); //True or False 个字符串之一的情况下返回一个布尔结果,你可以尝试这样的事情:

{{1}}

答案 2 :(得分:1)

LINQ Oneliner

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()

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

ToList() mid query的小指针。

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()

答案 3 :(得分:0)

试试这个:

List<string> TheListParameter = new List<string>{"string1", "string2", "string3"};
var result = MyDC.SomeTable.ToList().Select(l => l.SomeColumn)
                           .Where(l =>TheListParameter.Contains(l.SomeColumn)).ToList();