热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

关于Linqtosql实现模糊查询string数组

前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行,

前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时

//比如是这样一个数组条件:new string[]{"兴业银行","广州银行","xx银行","abc"}

我们不想在查询数据后,再对其进行模糊过滤操作,可能因为个人习惯,也可能由于项目需要不急于将Linq 的查询 过早的提交到数据库,我们需要先构建完查询条件最后才ToList()我的方案是用Expression来组装查询条件代码如下:

 1、创建一个IQueryable的拓展类

    public static class IQueryableExit
    {
        /// 
        /// 模糊查询一组数据,满足一组数据的模糊查询
        /// 
        /// 查询列表类型
        /// 查询数据源
        /// 模糊查询条件
        /// 要模糊查询的属性
        /// 返回模糊查询后的结果
        public static IQueryable QueryLikeArray(this IQueryable sqlData, IEnumerable array, string propertyName)
        {
            if (array == null || array.Count() == 0)
                return sqlData;
            if (string.IsNullOrEmpty(propertyName))
                throw new Exception("QueryLikeArray:propertyName未设置查询属性名称");
            var type = typeof(T);
            ParameterExpression param = Expression.Parameter(type);
            Expression filter1 = null;
            Expression filter2 = null;
            foreach (var item in array)
            {
                filter2 = Expression.Call(Expression.Property(param, type.GetProperty(propertyName)),
                typeof(String).GetMethod("Contains"), new Expression[] { Expression.Constant(item) });
                if (filter1 == null)
                    filter1 = filter2;
                else
                    filter1 = Expression.Or(filter1, filter2);
            }
            Expression pred = Expression.Lambda(filter1, param);
            MethodCallExpression whereCallExpression = Expression.Call(typeof(Queryable), "Where", new Type[] { type }, Expression.Constant(sqlData), pred);
            sqlData = sqlData.Provider.CreateQuery(whereCallExpression);
            return sqlData;
        }
    }

2、使用上面的拓展方法查询

        private void Query()
        {
            //查询条件,需要在单位表里面查询到所有包含 "兴业银行"和"广州银行" 字样的单位。
            var array = new List { "兴业银行", "广州银行" };
            //先查普通单位
            var sqlData = this._dataContext.Units.Where(w => w.isGeneral).AsQueryable();
            //调用模糊数组查询
            sqlData = sqlData.QueryLikeArray(array, "unitName");
            //追加Where条件
            sqlData = sqlData.Where(w => w.enable);
            //最后执行查询
            var t = sqlData.ToList();
        }
查询生成 的SQL 语句

SELECT [t0].[unitName], [t0].[enable], [t0].[isGeneral]....
FROM [dbo].[UNIT] AS [t0]
WHERE ([t0].[enable] = 1) AND (([t0].[unitName] LIKE @p0) OR ([t0].[unitName] LIKE @p1)) AND ([t0].[isGeneral] = 1)
-- @p0: Input NVarChar (Size = 4000; Prec = 0; Scale = 0) [%兴业银行%]
-- @p1: Input NVarChar (Size = 4000; Prec = 0; Scale = 0) [%广州银行%]
-- Context: SqlProvider(Sql2008) Model: AttributedMetaModel Build: 4.6.1038.0

虽然是比较浅薄的方式

若大家有更好的方法,请分享,谢谢!
END

推荐阅读
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 如何在php中将mysql查询结果赋值给变量
    本文介绍了在php中将mysql查询结果赋值给变量的方法,包括从mysql表中查询count(学号)并赋值给一个变量,以及如何将sql中查询单条结果赋值给php页面的一个变量。同时还讨论了php调用mysql查询结果到变量的方法,并提供了示例代码。 ... [详细]
  • 本文讨论了在使用sp_msforeachdb执行动态SQL命令时,当发生错误时如何捕获数据库名称。提供了两种解决方案,并介绍了如何正确使用'?'来显示数据库名称。 ... [详细]
  • Explain如何助力SQL语句的优化及其分析方法
    本文介绍了Explain如何助力SQL语句的优化以及分析方法。Explain是一个数据库SQL语句的模拟器,通过对SQL语句的模拟返回一个性能分析表,从而帮助工程师了解程序运行缓慢的原因。文章还介绍了Explain运行方法以及如何分析Explain表格中各个字段的含义。MySQL 5.5开始支持Explain功能,但仅限于select语句,而MySQL 5.7逐渐支持对update、delete和insert语句的模拟和分析。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了Perl的测试框架Test::Base,它是一个数据驱动的测试框架,可以自动进行单元测试,省去手工编写测试程序的麻烦。与Test::More完全兼容,使用方法简单。以plural函数为例,展示了Test::Base的使用方法。 ... [详细]
  • 本文介绍了在Vue项目中如何结合Element UI解决连续上传多张图片及图片编辑的问题。作者强调了在编码前要明确需求和所需要的结果,并详细描述了自己的代码实现过程。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • 集合的遍历方式及其局限性
    本文介绍了Java中集合的遍历方式,重点介绍了for-each语句的用法和优势。同时指出了for-each语句无法引用数组或集合的索引的局限性。通过示例代码展示了for-each语句的使用方法,并提供了改写为for语句版本的方法。 ... [详细]
  • 本文介绍了一种在PHP中对二维数组根据某个字段进行排序的方法,以年龄字段为例,按照倒序的方式进行排序,并给出了具体的代码实现。 ... [详细]
  • express工程中的json调用方法
    本文介绍了在express工程中如何调用json数据,包括建立app.js文件、创建数据接口以及获取全部数据和typeid为1的数据的方法。 ... [详细]
  • PHP引用的概念和用法详解
    本文详细介绍了PHP中引用的概念和用法。引用是指不同的变量名访问同一个变量内容,类似于Unix文件系统中的hardlink。文章从引用的定义、作用、语法和注意事项等方面进行了解释和示例。同时还介绍了对未定义变量使用引用的情况,以及在函数和new运算符中使用引用的注意事项。 ... [详细]
author-avatar
烟花凄美了谁的脸_234
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有