C#_LINQ数据查询

using System;
using System.Collections;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;

namespace CShapeTest
{
    class Master
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public int Age { get; set; }
        public string Kungfu { get; set; }
        public int Level { get; set; }

        public override string ToString()
        {
            return string.Format("Id:{0}, Name:{1}, Age:{2}, Kungfu:{3}, Level:{4}", Id, Name, Age, Kungfu, Level);
        }
    }

    class Kungfu
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public int Power { get; set; }

        public override string ToString()
        {
            return string.Format("Id:{0}, Name:{1}, Power:{2}", Id, Name, Power);
        }
    }

    class Start
    {
        static void Main(string[] args)
        {
            List<Master> masterList = new List<Master>();
            masterList.Add(new Master() { Id = 1, Name = "东风不败", Age = 35, Kungfu = "葵花宝典", Level = 10});
            masterList.Add(new Master() { Id = 2, Name = "林平之", Age = 23, Kungfu = "葵花宝典", Level = 7 });
            masterList.Add(new Master() { Id = 3, Name = "岳不群", Age = 50, Kungfu = "葵花宝典", Level = 8 });
            masterList.Add(new Master() { Id = 4, Name = "令狐冲", Age = 23, Kungfu = "孤独九剑", Level = 10 });
            masterList.Add(new Master() { Id = 5, Name = "梅超风", Age = 35, Kungfu = "九阴真经", Level = 8 });
            masterList.Add(new Master() { Id = 6, Name = "黄药师", Age = 50, Kungfu = "弹指神通", Level = 10 });
            masterList.Add(new Master() { Id = 7, Name = "风清扬", Age = 50, Kungfu = "孤独九剑", Level = 10 });

            List<Kungfu> kungfuList = new List<Kungfu>();
            kungfuList.Add(new Kungfu() { Id = 1, Name = "打狗棒法", Power = 90});
            kungfuList.Add(new Kungfu() { Id = 2, Name = "降龙十八掌", Power = 95 });
            kungfuList.Add(new Kungfu() { Id = 3, Name = "葵花宝典", Power = 100 });
            kungfuList.Add(new Kungfu() { Id = 4, Name = "孤独九剑", Power = 100 });
            kungfuList.Add(new Kungfu() { Id = 5, Name = "九阴真经", Power = 100 });
            kungfuList.Add(new Kungfu() { Id = 6, Name = "弹指神通", Power = 100 });

            // 查询武功等级大于8的大师

            // 使用foreach查询
            //List<Master> resList = new List<Master>();
            //foreach (var item in masterList)
            //{
            //    if (item.Level > 8)
            //    {
            //        resList.Add(item);
            //    }
            //}

            //foreach (var item in resList)
            //{
            //    Console.WriteLine(item);
            //}

            // 使用LINQ单一查询(表达式写法)
            //var resList = from m in masterList where m.Level > 8 && m.Age > 23 select m;
            //foreach (var item in resList)
            //{
            //    Console.WriteLine(item);
            //}

            // 使用LINQ单一查询(扩展方法写法)
            //var resList = masterList.Where((Master m) =>
            //{
            //    if (m.Level > 8 && m.Age > 23)
            //    {
            //        return true;
            //    }
            //    else
            //    {
            //        return false;
            //    }
            //});
            //foreach (var item in resList)
            //{
            //    Console.WriteLine(item);
            //}

            // 查询武功杀伤力大于90,并且年龄小于30的大师

            // 使用LINQ联合查询(表达式写法)
            //var resList = from m in masterList from k in kungfuList where m.Kungfu == k.Name && m.Age < 30 && k.Power > 90 select m;
            //foreach (var item in resList)
            //{
            //    Console.WriteLine(item);
            //}

            // 使用LINQ联合查询(扩展方法写法)
            //var resList = masterList.SelectMany((Master m) => kungfuList, (Master m, Kungfu k) => new {master = m, kungfu = k}).Where((x) => x.master.Kungfu == x.kungfu.Name && x.master.Age < 30 && x.kungfu.Power > 90);
            //foreach (var item in resList)
            //{
            //    Console.WriteLine(item);
            //}

             使用LINQ单一查询的同时,进行排序(表达式写法)
            //var resList = from m in masterList where m.Level > 8 orderby m.Age,m.Level select m;
            //foreach (var item in resList)
            //{
            //    Console.WriteLine(item);
            //}

            // 使用LINQ单一查询的同时,进行排序(扩展方法写法)
            var resList = masterList.Where(m => m.Level > 8).OrderBy(m => m.Age).ThenBy(m => m.Level);
            foreach (var item in resList)
            {
                Console.WriteLine(item);
            }

            Console.ReadLine();
        }
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值