簡體   English   中英

實體框架4.1 Linq包含和StartsWith

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM