C# Lambda表达式和linq表达式 之 匿名对象查询接收

简介: C# Lambda表达式和linq表达式 之 匿名对象查询接收

很多小伙伴都用过Lambda表达式和linq表达式,用起来也得心应手,但是有的小伙伴

对匿名对象的查询与接收比较迷茫,(没有定义相应的实体),怎么在where()里面进行

条件筛选呢?常规用法我就不说了,我们来说一下匿名对象怎么操作。

我们先看一下Lambda表达式的形式:

Lambda表达式 说明
x=>x*x 返回参数值的平方
x=>{return x*x;} 返回参数值的平方。主体是语句块
int(x)=>x/2 返回参数值除以2的结果
{}=>folder.StopFolding(0) 调用一个方法,表达式不获取参数。表达式可能会、也可能不会返回值
(x,y)=>{x++;return x/y;} 多个参数,编译器自己推导参数类型。参数x是以值得形式传递的,所以+ +操作的效果是局部于表达式
(ref int x,y){X++;returnx/y;} 多个 参数,都显示指定类型。参数x的类型是以引用的形式传递的,所以+ +操作的效果是永久性的

 

然后用过Dictionary<>的童鞋都知道,它的循环取值是 item["列名"],那么我们也可以使用这种方式

进行操作,且看如下代码:

List<Dictionary<string, object>> Listdict = new List<Dictionary<string, object>>();
Dictionary<string, object> dict1 = new Dictionary<string, object>();
dict1.Add("Id", 1);
dict1.Add("name", "老大");
dict1.Add("avg", 5);
Listdict.Add(dict1);
Dictionary<string, object> dict2 = new Dictionary<string, object>();
dict2.Add("Id", 2);
dict2.Add("name", "老二");
dict2.Add("avg", 10);
Listdict.Add(dict2);
Dictionary<string, object> dict3 = new Dictionary<string, object>();
dict3.Add("Id", 3);
dict3.Add("name", "老三");
dict3.Add("avg", 20);
Listdict.Add(dict3);
Dictionary<string, object> dict4 = new Dictionary<string, object>();
dict3.Add("Id", 3);
dict3.Add("name", "老四");
dict3.Add("avg", 30);
Listdict.Add(dict4);
//1:查询Id等于2的用户
//Lambda表达式(与Lambda表达式相关的整条语句称作什么呢?在微软并没有给出官方的命名,在《深入理解C#》中称为点标记)。
var temp = Listdict.Where(it => { return Convert.ToInt32(it["Id"]) == 2; }).ToList();
//2:查询avg大于9的和
//Lambda表达式(与Lambda表达式相关的整条语句称作什么呢?在微软并没有给出官方的命名,在《深入理解C#》中称为点标记)。
var temp2 = Listdict.Where(it => { return Convert.ToInt32(it["avg"]) > 9; }).Sum(it => Convert.ToInt32(it["avg"]));
//linq表达式 (查询表达式)
var temp3 = (from it in Listdict where Convert.ToInt32(it["avg"]) > 9 select Convert.ToInt32(it["avg"])).Sum();
//3、排序
Listdict = Listdict.OrderByDescending(it => Convert.ToInt32(it["Id"])).ToList();
//联接(这里只展示内联接)Join
var temp5 = from a in Listdict
join b in Listdict
on a["Id"] equals b["Id"]
select new
{
Id = a["Id"],
Name = a["name"],
avg = a["avg"]
};

看了上面的是不是突然觉得茅塞顿开,他的不同点只是匿名对象的列名和实体的列名获取方式不一样罢了。

小伙伴们快去试试吧!发现更多应用可以留言讨论哦^_^

相关文章
|
2月前
|
开发框架 .NET API
以C#一分钟浅谈:GraphQL 数据类型与查询
本文从C#开发者的角度介绍了GraphQL的基本概念、核心组件及其实现方法。GraphQL由Facebook开发,允许客户端精确请求所需数据,提高应用性能。文章详细讲解了如何在C#中使用`GraphQL.NET`库创建Schema、配置ASP.NET Core,并讨论了GraphQL的数据类型及常见问题与解决方案。通过本文,C#开发者可以更好地理解并应用GraphQL,构建高效、灵活的API。
126 64
|
18天前
|
程序员 C# 数据库
C# 比较对象新思路,利用反射技术打造更灵活的比较工具
中途接手的项目,碰到需要在更新对象信息时比较并记录差异的需求,最变态的还有附加要求,怎么办?有没有既能满足需求又能对项目影响最小的方法呢?分享这个我封装的方法,一个利用反射技术打造的更灵活的比较工具
|
3月前
|
编译器 C#
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
137 65
|
1月前
|
开发框架 .NET 测试技术
C# 一分钟浅谈:GraphQL 数据类型与查询
本文介绍了GraphQL的基本概念、数据类型及查询方法,重点从C#角度探讨了GraphQL的应用。通过Hot Chocolate库的实例,展示了如何在ASP.NET Core中实现GraphQL API,包括安装、定义Schema、配置及运行项目。文中还讨论了常见问题与解决方案,旨在帮助开发者更好地理解和使用GraphQL。
43 2
|
2月前
|
JSON 程序员 C#
使用 C# 比较两个对象是否相等的7个方法总结
比较对象是编程中的一项基本技能,在实际业务中经常碰到,比如在ERP系统中,企业的信息非常重要,每一次更新,都需要比较记录更新前后企业的信息,直接比较通常只能告诉我们它们是否指向同一个内存地址,那我们应该怎么办呢?分享 7 个方法给你!
|
3月前
|
SQL 缓存 分布式计算
C#如何处理上亿级数据的查询效率
C#如何处理上亿级数据的查询效率
58 1
|
4月前
|
开发框架 自然语言处理 .NET
C#一分钟浅谈:LINQ 查询表达式的使用技巧
【9月更文挑战第6天】LINQ(Language Integrated Query)是C#开发中的强大工具,使查询数据集合变得简单且接近自然语言。本文从基础入手,通过具体示例讲解LINQ查询表达式的使用技巧,包括过滤、排序和分组等操作。同时,文章还探讨了常见问题及解决方法,如性能优化、过早枚举和类型转换等,帮助开发者写出更高效、易维护的代码。
110 15
|
4月前
|
C#
C#一分钟浅谈:Lambda 表达式和匿名方法
本文详细介绍了C#编程中的Lambda表达式与匿名方法,两者均可用于定义无名函数,使代码更简洁易维护。文章通过基础概念讲解和示例对比,展示了各自语法特点,如Lambda表达式的`(parameters) =&gt; expression`形式及匿名方法的`delegate(parameters)`结构。并通过实例演示了两者的应用差异,强调了在使用Lambda时应注意闭包问题及其解决策略,推荐优先使用Lambda表达式以增强代码可读性。
57 8
|
4月前
|
C# 数据安全/隐私保护
C# 一分钟浅谈:类与对象的概念理解
【9月更文挑战第2天】本文从零开始详细介绍了C#中的类与对象概念。类作为一种自定义数据类型,定义了对象的属性和方法;对象则是类的实例,拥有独立的状态。通过具体代码示例,如定义 `Person` 类及其实例化过程,帮助读者更好地理解和应用这两个核心概念。此外,还总结了常见的问题及解决方法,为编写高质量的面向对象程序奠定基础。
39 2
|
2月前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
44 3