c# – 实体框架LINQ不包含不区分大小写

栏目: ASP.NET · 发布时间: 5年前

内容简介:翻译自:https://stackoverflow.com/questions/25310750/entity-framework-linq-contains-not-case-insensitive

我有一些’撕掉我的头发’ – 实体框架的问题,我找不到解决方案.

我想要做的是比较我在服务器上运行的搜索功能的字符串.它基本上是:collection.Where(c => c.Name.Contains(searchTerm));其中searchTerm是用户传递的字符串.

我到处都看到了:

>使用toUpper()更改两个字符串,或

>将 排序 规则设置为不区分大小写.

然而,这些都不适用于我的情况.这是一个类似的问题,没有答案: Entity Framework – case insensitive Contains?

使用第一个替代方法将导致获取数据库中的每一行,然后执行toUpper(),以查看它是否匹配.这在性能方面是不可接受的.

第二种方法似乎更有可能是一种有效的解决方案,但由于某种原因不起作用.我有两个数据库.一个本地和一个远程.远程MSSQL数据库设置为排序规则:Finnish_Swedish_CI_AS,这意味着它不区分大小写?本地数据库是一个自动生成的localDB,其属性“Case Sensitive”设置为False.

无论我使用它的这两个数据库中的哪一个,对用户来说仍然总是区分大小写.

有人可以解释为什么会这样,所以我可以继续我悲惨的生活吗?

亲切的问候,

罗宾多尔贝尔

从评论中,听起来OP首先将IQueryable列表转换为ICollection,这意味着任何后续LINQ都在“本地”运行而不是有机会转换为SQL.

例如,

// Should be IQueryable<T>
    ICollection<User> users = context.Users;

    // This is executed in code rather than SQL, and so is case SENSITIVE
    users = users.Where(c => c.Name.Contains(searchTerm));

这可能有助于调试问题: How do I view the SQL generated by the entity framework?

翻译自:https://stackoverflow.com/questions/25310750/entity-framework-linq-contains-not-case-insensitive


以上所述就是小编给大家介绍的《c# – 实体框架LINQ不包含不区分大小写》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

ActionScript 3.0精彩范例词典

ActionScript 3.0精彩范例词典

杨东昱 编 / 2008-5 / 59.00元

《ActionScript 3.0精彩范例词典》列出了最常用的ActionScript语法,并附有详细的程序代码范例,不但教您如何使用、修改ActionScript代码,而且还以实际范例和图解,说明每项语法还能呈现哪些动画效果和功能,对学习ActipScript有所帮助。读者在阅读《ActionScript 3.0精彩范例词典》之后,将能开发出属于自己的ActionScript程序与FLASH动画......一起来看看 《ActionScript 3.0精彩范例词典》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

html转js在线工具
html转js在线工具

html转js在线工具