不区分大小写的"包含" Linq中 [英] Case-insensitive "contains" in Linq

查看:287
本文介绍了不区分大小写的"包含" Linq中的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有我在它使用LINQ一个MVC项目。
我的数据库中有一些记录,比如Someth ING,SOmeTH ING,someTh ING,SOMETH ING,someTH ING

I have a mvc project which I use linq in it. In my database there is some records, for example "Someth ing","SOmeTH ing","someTh ing","SOMETH ING","someTH ING"

我想这样做:

SELECT * FROM dbo.doc_dt_records WHERE name LIKE '%' + @records.Name + '%'

但是,如果我运行此代码,list.Count返回0。我该怎么办?

However if I run this code, list.Count returns 0. What should I do?

    records.Name = "someth ing"; //for example
    var rec = db.Records.ToList();
         var lists = rec.Where(p => p.Name.Contains(records.Name)).ToList();
if (lists.Count > 0)
{
    // do sthng
}

感谢您的帮助...

推荐答案

简单的方法是使用ToLower将( )方法

the easy way is to use ToLower() method

var lists = rec.Where(p => p.Name.ToLower().Contains(records.Name.ToLower())).ToList();



一个更好的解决方案(基于这个帖子:的不区分大小写'包含(字符串)

 var lists = rec.Where(p => 
             CultureInfo.CurrentCulture.CompareInfo.IndexOf
             (p.Name, records.Name, CompareOptions.IgnoreCase) >= 0).ToList();

这篇关于不区分大小写的"包含" Linq中的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆