不区分大小写的 LINQ(没有 toUpper 或 toLower)
public Articles GetByName(string name, Categories category, Companies company)
{
var query = from article in session.Linq<Articles>()
where article.Name == name &&
article.Category == category &&
article.Company == company
select article;
return query.FirstOrDefault();
}
如何使LINQ查询不区分大小写?我可以使用 toLower()
或 toUpper()
,但我想改用 OrdinalIgnoreCase
。是否可以?
public Articles GetByName(string name, Categories category, Companies company)
{
var query = from article in session.Linq<Articles>()
where article.Name == name &&
article.Category == category &&
article.Company == company
select article;
return query.FirstOrDefault();
}
How to make the LINQ query case-insensitive? I can use toLower()
or toUpper()
, but I want to use OrdinalIgnoreCase
instead. Is it possible?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(8)
将
String.Equals
与适当的参数一起使用以使其不区分大小写Use
String.Equals
with the appropriate parameters to make it case insensitive使用
.Equals(name, StringComparison.OrdinalIgnoreCase)
方法代替==
。Instead of
==
use the.Equals(name, StringComparison.OrdinalIgnoreCase)
method.如果这是针对具有不区分大小写排序规则的数据库的 LINQ to SQL 查询,则它已经是不区分大小写的。请记住,LINQ to SQL 实际上并不执行您的 == 调用;而是执行您的 == 调用。它将其视为一个表达式并将其转换为 SQL 中的等式运算符。
如果它是 LINQ to Objects,那么您可以使用 String.Equals,正如其他发帖者指出的那样。
If this is a LINQ to SQL query against a database with a case-insensitive collation, then it already is case-insensitive. Remember that LINQ to SQL isn't actually executing your == call; it's looking at it as an expression and converting it to an equality operator in SQL.
If it's LINQ to Objects, then you can use String.Equals as the other posters have pointed out.
它还会处理名称、类别、公司为
null
的情况It will also handle when Name,Category,Company is
null
如果您使用的是 C# 6.0,则可以定义在构造 LINQ 语句时使用的简短扩展方法:
用法:
对于低于 6.0 的 C#,它将如下所示:
If you are using C# 6.0 you can define a short extension method to be used when constructing LINQ statements:
Usage:
For C# less than 6.0 it will look like this:
使用
Use
将其更改为
Change it to
使用
当您确定您的数据库支持它时
。例如,具有
NOCASE
排序规则的 SQLite 将忽略该选项。Oracle 使用将要采用的会话设置
NLS_COMP
、NLS_SORT
。如果没有文化问题,则可以使用
ToLower()
或ToUpper()
。Use
when you are sure that your database supports it.
E.g. SQLite with a collate of
NOCASE
will ignore the option.Oracle uses session settings
NLS_COMP
,NLS_SORT
that will be taken.Else use
ToLower()
orToUpper()
when you have no culture issues.