前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LINQ多条件OR模糊查询

LINQ多条件OR模糊查询

作者头像
跟着阿笨一起玩NET
发布2018-09-19 11:42:00
1.6K0
发布2018-09-19 11:42:00
举报

本文章转载:http://www.cnblogs.com/guyun/archive/2012/10/18/2729888.html

需求是这样的,有一张表tbl(Key[int],Value[string]),数据存储如下:

Key

Value

1

-a-b-

2

-a-

3

-c-e-

4

-f-g-

现在的目的是要从tbl表中取出所有Value字段的值和List的值匹配的记录。本地有个List<string>{"a","b","c"};

传统的T-SQL写法是:select * from tbl where Value like '%a%' or Value like '%b%' or Value like '%c%' 如何用linq实现呢?

我第一个想到的是这样的:

var query=from q in tbl select q;

foreach(var item in list) { query=query.Where(r=>r.Value.Contains(item)); }

但是这样做生成的T_SQL语句是:select * from tbl where Value like '%a%' and Value like '%b%' and Value like '%c%'

同样也可以像SQL语句这样:select * from tb1 as a inner join tb2  as b on a.value like  "%'+b.value; 

唉,真蛋疼,百度了好多全都无解,最后看到了一篇帖子,给了我点启发,帖子链接如下:http://social.msdn.microsoft.com/Forums/de-DE/238/thread/b8ea22a7-f733-4ff5-8333-0dd3fe558076

经过思路整理,最终代码如下:

    class Program

    {

        static void Main(string[] args)

        {

            var dt = new DataTable();

            dt.Columns.Add("Key", typeof (int));

            dt.Columns.Add("Value", typeof (string));

            dt.Rows.Add(1, "-a-b-");

            dt.Rows.Add(2, "-a-");

            dt.Rows.Add(3, "-c-e-");

            dt.Rows.Add(4, "-f-g-");

            var list = new List<string> {"a", "b", "c"};

            var query = from q in dt.AsEnumerable()

                        from t in list

                        where q.Field<string>("Value").Contains(t)

                        select q;

            var vdt = query.Distinct().CopyToDataTable();

            foreach (DataRow dr in vdt.Rows)

            {

                Console.WriteLine(dr["Key"] + "\t" + dr["Value"]);

            }

        }

    }

大功告成,输出结果如下:

1 -a-b-
2 -a-
3 -c-e-
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2014-07-20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据保险箱
数据保险箱(Cloud Data Coffer Service,CDCS)为您提供更高安全系数的企业核心数据存储服务。您可以通过自定义过期天数的方法删除数据,避免误删带来的损害,还可以将数据跨地域存储,防止一些不可抗因素导致的数据丢失。数据保险箱支持通过控制台、API 等多样化方式快速简单接入,实现海量数据的存储管理。您可以使用数据保险箱对文件数据进行上传、下载,最终实现数据的安全存储和提取。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档