检查 table 是否包含列表中的值
Checking if a table contains values in a list
我有一个字符串参数列表,我想编写一个查询 returns 一个字符串列表,其中包含 table 中存在的参数列表的值。我有以下查询,但无法获取 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
子句?
尝试关注
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();
基于 Contain
的 Documentation,Contains
的参数可能是 string
而不是字符串列表。所以应该是这样的:
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();
或者如果 return 如果 MyDC.SomeTable.SomeColumn
包含 TheListParameter
的字符串之一,您想要一个布尔结果,您可以尝试这样的事情:
bool hasSameElements = MyDC.SomeTable.ToList()
.Select(c => c.SomeColumn)
.Intersect(TheListParameter).Any(); //True or False
试试这个:
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();
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()
现在,如果你有全局或本地(不是 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()
我有一个字符串参数列表,我想编写一个查询 returns 一个字符串列表,其中包含 table 中存在的参数列表的值。我有以下查询,但无法获取 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
子句?
尝试关注
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();
基于 Contain
的 Documentation,Contains
的参数可能是 string
而不是字符串列表。所以应该是这样的:
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();
或者如果 return 如果 MyDC.SomeTable.SomeColumn
包含 TheListParameter
的字符串之一,您想要一个布尔结果,您可以尝试这样的事情:
bool hasSameElements = MyDC.SomeTable.ToList()
.Select(c => c.SomeColumn)
.Intersect(TheListParameter).Any(); //True or False
试试这个:
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();
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()
现在,如果你有全局或本地(不是 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()