LINQ の Contains メソッドを使用した大文字と小文字を区別しない文字列比較
LINQ クエリで文字列比較を行う場合は、大文字と小文字を区別することを考慮することが重要です。デフォルトでは、Contains メソッドは大文字と小文字を区別します。つまり、「CaseSensitive」と「casesensitive」は一致しません。
問題:
次の LINQ クエリでは、説明フィルターに基づいて FACILITY_ITEM エンティティを取得することを目的としています。ただし、クエリでは現在大文字と小文字が区別されるため、目的の結果が返されない可能性があります。
public IQueryable<FACILITY_ITEM> GetFacilityItemRootByDescription(string description) { return this.ObjectContext.FACILITY_ITEM.Where(fi => fi.DESCRIPTION.Contains(description)); }
解決策:
比較で大文字と小文字を区別しないようにするには、次のようにします。 Contains チェックを実行する前に、ToLower() メソッドを利用してください。これにより、説明フィルターとデータベース値の両方が小文字に変換され、大文字と小文字を区別しない比較が保証されます。
fi => fi.DESCRIPTION.ToLower().Contains(description.ToLower())
この更新された式を使用すると、クエリは施設アイテムの説明が説明フィルターと一致する結果を返します。大文字と小文字の区別はありません。
以上がLINQ の Contains メソッドを使用して、大文字と小文字を区別しない文字列比較を実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。