c#包含不区分大小写的搜索

时间:2014-04-13 07:44:20

标签: c# .net asp.net-mvc-3 asp.net-mvc-4

我有以下代码

var returnData = DemoData.Books.AsQueryable();

if (criteria.Author != string.Empty)
{
    returnData = returnData.Where(x => x.Author.Contains(criteria.Author));
}

如何使where子句不区分大小写?

2 个答案:

答案 0 :(得分:28)

  1. 您可以使用ToLower()功能。 ToLower将字符串更改为全部小写。它会转换整个字符串,而不会更改已经小写或数字的字母。它复制一个字符串并返回对新字符串的引用。因此,在查询之外声明criteria.Author.ToLower()总是更好的选择。

    string lowerAuthor = criteria.Author.ToLower();
    returnData = returnData.Where
            (x => x.Author.ToLower().Contains(lowerAuthor));
    
  2. 您还可以对IndexOf枚举使用StringComparison重载。它会比ToLower()提供更好的性能。此重载的签名是:

    int string.IndexOf(string value, StringComparison comparisonType);
    

    returnData = returnData.Where
        (x => x.Author.IndexOf(criteria.Author, StringComparison.CurrentCultureIgnoreCase) != -1);
    

答案 1 :(得分:6)

returnData = returnData.Where
        (x => x.Author.IndexOf(criteria.Author, StringComparison.CurrentCultureIgnoreCase) != -1)

根本不会进行额外的字符串分配。

我认为它是LINQ to Objects查询。