Linq联合查询

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace LINQ01
{
    class Program
    {
        static void Main(string[] args)
        {
            //初始化武林高手
            var masterList = new List<MartialArtsMaster>()
             {
                new MartialArtsMaster(){ Id = 1, Name = "黄蓉",    Age = 18, Menpai = "丐帮", Kongfu = "打狗棒法",  Level = 9  },
                new MartialArtsMaster(){ Id = 2, Name = "洪七公",  Age = 70, Menpai = "丐帮", Kongfu = "打狗棒法",  Level = 10 },
                new MartialArtsMaster(){ Id = 3, Name = "郭靖",    Age = 22, Menpai = "丐帮", Kongfu = "降龙十八掌",Level = 10 },
                new MartialArtsMaster(){ Id = 4, Name = "任我行",  Age = 50, Menpai = "明教", Kongfu = "葵花宝典",  Level = 1  },
                new MartialArtsMaster(){ Id = 5, Name = "东方不败",Age = 35, Menpai = "明教", Kongfu = "葵花宝典",  Level = 10 },
                new MartialArtsMaster(){ Id = 6, Name = "林平之",  Age = 23, Menpai = "华山", Kongfu = "葵花宝典",  Level = 7  },
                new MartialArtsMaster(){ Id = 7, Name = "岳不群",  Age = 50, Menpai = "华山", Kongfu = "葵花宝典",  Level = 8  },
                new MartialArtsMaster() { Id = 8, Name = "令狐冲", Age = 23, Menpai = "华山", Kongfu = "独孤九剑", Level = 10 },
                new MartialArtsMaster() { Id = 9, Name = "梅超风", Age = 23, Menpai = "桃花岛", Kongfu = "九阴真经", Level = 8 },
                new MartialArtsMaster() { Id =10, Name = "黄药师", Age = 23, Menpai = "梅花岛", Kongfu = "弹指神通", Level = 10 },
                new MartialArtsMaster() { Id = 11, Name = "风清扬", Age = 23, Menpai = "华山", Kongfu = "独孤九剑", Level = 10 }
            };
            //初始化武学
            var kongfuList = new List<Kongfu>()
            {
                new Kongfu(){Id=1, Name="打狗棒法", Power=90},
                new Kongfu(){Id=2, Name="降龙十八掌",Power=95},
                new Kongfu(){Id=3, Name="葵花宝典", Power=100},
                new Kongfu(){Id=4, Name="独孤九剑", Power = 100 },
                new Kongfu(){Id=5, Name="九阴真经", Power = 100 },
                new Kongfu(){Id=6, Name="弹指神通", Power = 100 }
            };
            //方法一:查询所有开学级别大于8的高手
            //var res = new List<MartialArtsMaster>();
            //foreach (var temp in masterList)
            //{
            //    if (temp.Level > 8)
            //    {
            //        res.Add(temp);
            //    }
            //}
            //方法二:使用linq查寻(表达式与法)
            //var res = from m in masterList//from后面设置查询的集合
            //          where m.Level > 8 && m.Menpai == "丐帮"//条件语句可以用&&或||
            //          select m.Name;//把m的集合返回

            //方法三:扩展方法的写法.where(过滤方法),意思就是这个方法会遍列自身的所有成员并当作参数分别传入过滤方法,在过滤方法中进行所要的判断。
            //var res = masterList.Where(Test1);//
            //方法四:一般直接使用lamda表达式
            //var res = masterList.Where(m=>m.Level>8 && m.Menpai== "丐帮");

            //运用一:联合查询(表达式法)
            //查询Powe>90的Naster
            //var res = from m in masterList
            //          from k in kongfuList
            //          where m.Kongfu==k.Name && k.Power > 90
            //          select new { master=m,kongfu=k};

            //运用二:联合查询(扩展方法法)
            //说明:m => kongfuList是 masterList.SelectMany另一个查询对象,
            //(m, k) => new { master = m, Kongfu = k }是将两个欲查询的对象用lamda表达式建立一个新的new { master = m, Kongfu = k }集合,这里边的就是两个查询对象的合集(from m in masterList  from k in kongfuList)
            // Where(x=>x.master.Kongfu==x.Kongfu.Name);就是条例语句
            //var res = masterList.SelectMany(m => kongfuList, (m, k) => new { master = m, Kongfu = k });
           var res = masterList.SelectMany(m => kongfuList, (m, k) => new { master = m, Kongfu = k }).Where(x=>x.master.Kongfu==x.Kongfu.Name &&x.Kongfu.Power>90);
            foreach (var temp in res)
            {
                Console.WriteLine(temp.ToString());
            }
            Console.WriteLine(res.Count());

            Console.ReadKey();
        }
        //过滤方法
        static bool Test1(MartialArtsMaster master)
        {
            if (master.Level > 8 && master.Menpai == "丐帮") return true;
            return false;
        }
    }
}
时间: 2024-07-30 09:30:15

Linq联合查询的相关文章

LINQ(数据查询)

如果只有空的构造函数,想要对字段进行初始化,可以直接在构造函数后面加上{属性名=值,属性名=值};属性与属性之间用,分割开 //查询所有武学级别大于8的武林高手 //var res = new List<MartialArtsMaster>(); //foreach (var temp in masterList) //{ // if (temp.Level > 8) // { // res.Add(temp); // } //} //1,使用LINQ做查询( 表达式写法) //var

linq中如何实现多个条件的联合查询

目前接触处理数据这一块比较多,在处理内存中的数据源的时候我一般使用的是linq,linq使用起来像sql语句一样,用法简单,功能强大. 最近需要实现一个从两个不同的文件读取不同的数据,然后根据这两个数据的一些字段经行联合,然后把他们的结果放到一个数据源里面里啊,一般的联合查询两个数据源,都是通过一个数据源的字段和另一个数据源的字段经行匹配就可以了,如果是这样的话在linq实现和在sql里面实现其实差不多,下面是单个条件的联合查询的代码如下所示 var result1 = from l1 in l

EF 表联合查询 join

有两张表m_Dept.m_User,联合查询 linq方式.EF方式 private void Add() { List<m_Dept> lst = new List<m_Dept>{ new m_Dept { DName = "开发", ID = "1" }, new m_Dept { DName = "测试", ID = "2" }, new m_Dept { DName = "财务&qu

MVC5+EF6简单实例---以原有SQLServer数据库两表联合查询为例

工具:VS.net2013.EF6.MVC5.SQLServer2008 参考出处: http://www.cnblogs.com/slark/p/mvc-5-get-started-create-project.html http://www.cnblogs.com/miro/p/4288184.html http://www.cnblogs.com/dotnetmvc/p/3732029.html 一.准备工作 在SqlServer上创建数据库:Element 模拟两个表并插入数据:SysU

Linq 标准查询操作符三

本文介绍了LINQ标准查询操作符.没有这些操作符,LINQ就不会存在.本文为理解这些操作符的功能提供了很好的基础.了解它们将会很有帮助,因为LINQ的各种Provider都是基于这些操作符来完成各自丰富的功能. 一.投影操作符 1. Select Select操作符对单个序列或集合中的值进行投影.下面的示例中使用select从序列中返回Employee表的所有列: using (NorthwindDataContext db = new NorthwindDataContext()) { //查

数据库之联合查询和连接查询

http://blog.csdn.net/memgxingfeixiang/article/details/52765208 1.JOIN和UNION区别join 是两张表做交连后里面条件相同的部分记录产生一个记录集,union是产生的两个记录集(字段要一样的)并在一起,成为一个新的记录集. JOIN用于按照ON条件联接两个表,主要有四种:INNER JOIN:内部联接两个表中的记录,仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行.我理解的是只要记录不符合ON条件,就不会显示在结果集

Linq高级查询与分页查询

Linq高级查询 以~开头: r=>r.Name.StartsWith("李"); 以~结尾: r=>r.Name.EndsWith("光"); 包含(模糊查询): r=>r.Name.Contains("四"); 数据总个数: Con.Goods.Count();||Con.Users.ToList().count; 最大值: Con.Goods.ToList().Max(r=>r.Price); 最小值: Con.Go

MySQL的查询,子查询,联结查询,联合查询

一.mysql查询的五种子句where(条件查询).having(筛选).group by(分组).order by(排序).limit(限制结果数) 二.子查询1.where 子查询SELECT * FROM tb1 WHERE cat_id IN (SELECT max(id) FROM tb2 GROUP BY cat_id); 2.from 子查询SELECT t2_id FROM (SELECT t2_id FROM tb2 ORDER BY t2_id DESC); 3.exists

两个表联合查询获取聊天表中用户最新的一条聊天数据

一个用户表,一个聊天记录表,两个表联合查询获取聊天表中用户最新的一条聊天数据 select c.contentfrom sixin as c where c.tid = a.user_idorder by ctime desc limit 0,1) as content,(select c.statusfrom sixin as c where c.tid = a.user_idorder by ctime desc limit 0,1) as status from users as a, s