[英]Entity Framework 4.1 Linq Contains and StartsWith
我正在使用Entity Framework Code First。 我想從數據庫查詢針對List對象的entites。 這適用於contains,但是如何將它與StartsWith結合使用?
這是我的代碼:
List<string> values = new List<string>();
values.Add("A");
values.Add("B");
context.Customer.Where(c => values.Contains(c.Name)).ToList();
如何查詢以A或B開頭的所有客戶?
這應該在內存中工作,但我不確定它是否可以被EF翻譯成SQL:
context.Customer.Where(c => values.Any(s => c.Name.StartsWith(s))).ToList();
你不需要將它與StartsWith結合使用,因為如果它以A或B開頭,那么它顯然包含A或B.它不能以A或B開頭而不包含A或B.
所以只需使用StartsWith而不是Contains。
context.Customer.Where(c => c.StartsWith("A") || c.StartsWith("B")).ToList();
您可以嘗試以這種方式組合這兩個函數:
IQueryable<Customer> result = (from C in context.Customerwhere C.Name.StartsWith("B") && values.Contains(C.Name));
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.