-
C#教程之C#教程之EF SQLite的Like语句,生成为CHARINDEX的解决
本站最新发布 C#从入门到精通
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
在使用EF SQLite的时候发现Like语句不能完全查询出来,看了下生成的SQL语句类似于这种
1
|
(CHARINDEX(@p__linq__2, [Extent1].[LeagueName])) > 0) |
查了下资料,在SQLite中是不支持CHARINDEX这个函数的,其实解决办法很简单,我们只要自己实现个Interceptor,再替换一下SQL语句,然后添加到EF中就可以了,下面是Interceptor的实现:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
private static Regex replaceRegex = new Regex( @"\(\(CHARINDEX\((.*?), (.*?)\)\) > 0\)" ); private void ReplaceCharIndexFunc(DbCommand command) { var flag = false ; var text = replaceRegex.Replace(command.CommandText, m => { if (!m.Success) return m.Value; flag = true ; var key = m.Groups[1].Value; var name = m.Groups[2].Value; //替换参数 foreach (DbParameter commandParameter in command.Parameters) { if (commandParameter.ParameterName == key.Substring(1)) { commandParameter.Value = $ "%{commandParameter.Value}%" ; break ; } } return $ "{name} LIKE {key}" ; }); if (flag) command.CommandText = text; } |
栏目列表
最新更新
如何使用OS模块中的stat方法
Python os 模块
seek() 方法
python打开文件实例1
Python写入文件
什么是流?
文件操作如何进制逐行读取
Python相对路径
with创建临时运行环境
Python文件操作
.Net Standard(.Net Core)实现获取配置信息
Linux PXE + Kickstart 自动装机
Shell 编程 基础
Shell 编程 条件语句
CentOS8-网卡配置及详解
Linux中LVM逻辑卷管理
1.数码相框-相框框架分析(1)
Ubuntu armhf 版本国内源
Linux中raid磁盘阵列
搭建简易网站
access教程之Access简介
mysql 安装了最新版本8.x版本后的报错:
Mysql空间数据&空间索引(spatial)
如何远程连接SQL Server数据库的图文教程
复制SqlServer数据库的方法
搜索sql语句
sql中返回参数的值
sql中生成查询的模糊匹配字符串
数据定义功能
数据操作功能