内容简介:翻译自: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不包含不区分大小写》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- mysql查询条件-不区分大小写
- 重构之路:webpack区分生产环境和开发环境
- 当 AI 医疗成为热点,噱头与实干如何区分?
- (译)React是如何区分Class和Function?
- 面试篇---1 如何区分深拷贝与浅拷贝
- React是如何区分class和function的?
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
30天自制操作系统
[日] 川合秀实 / 周自恒、李黎明、曾祥江、张文旭 / 人民邮电出版社 / 2012-8 / 99.00元
自己编写一个操作系统,是许多程序员的梦想。也许有人曾经挑战过,但因为太难而放弃了。其实你错了,你的失败并不是因为编写操作系统太难,而是因为没有人告诉你那其实是一件很简单的事。那么,你想不想再挑战一次呢? 这是一本兼具趣味性、实用性与学习性的书籍。作者从计算机的构造、汇编语言、C语言开始解说,让你在实践中掌握算法。在这本书的指导下,从零编写所有代码,30天后就可以制作出一个具有窗口系统的32位......一起来看看 《30天自制操作系统》 这本书的介绍吧!