zoukankan      html  css  js  c++  java
  • EF SQLite的Like语句,生成为CHARINDEX的解决办法

      在使用EF SQLite的时候发现Like语句不能完全查询出来,看了下生成的SQL语句类似于这种 

    (CHARINDEX(@p__linq__2, [Extent1].[LeagueName])) > 0)
    

      查了下资料,在SQLite中是不支持CHARINDEX这个函数的,其实解决办法很简单,我们只要自己实现个Interceptor,再替换一下SQL语句,然后添加到EF中就可以了,下面是Interceptor的实现:

    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;
            }
    

      首先是正则替换掉所有的CHARINDEX,然后是修改查询的值。然后我们在EF中把Interceptor添加上去:

    public QiuTanDb() : base("name=defaultConn")
            {
                DbInterception.Add(new SqliteInterceptor());
            }
    

      

  • 相关阅读:
    mysql面试题
    Excel下载打不开
    Linux安装jdk1.8和配置环境变量
    Linux压缩、解压文件
    Linux常用命令1
    VMware下载安装及CentOS7下载安装
    ueditor的简单配置和使用
    linux的tomcat服务器上部署项目的方法
    TortoiseSVN客户端的使用说明
    CentOS 6.5系统上安装SVN服务器
  • 原文地址:https://www.cnblogs.com/mldcy/p/8287575.html
Copyright © 2011-2022 走看看