LAMBDA表达式常用写法

这里主要是将数据库中的常用操作用LAMBDA表达式重新表示了下,用法不多,但相对较常用,等有时间了还会扩展,并将查询语句及LINQ到时也一并重新整理下:

1.select语句:books.Select(p=>new { p.Title, p.UnitPrice, p.Author});//需用匿名方式

2.where语句:books.Where(p=>p.UnitPrice==100&&p.Title=”ABC”);

补充:

像数据库中的LIKE ‘%c++%’,LAMBDA中用p.Title.Contains(“c++”)表示;

像数据库中的LIKE ‘c%’,LAMBDA中用p.Title.StartWith(“c”)表示;

像数据库中的LIKE ‘%c’,LAMBDA中用p.Title.EndsWith(“c”)表示;

Where的另一种表现形式:

books.Where(p=>{

var ret = p.UnitPrice>30&&p.Title.Contains(“c++”);

return ret;

});

3.排序语句:

像数据库中order by 升序:

通过 “对象.OrderBy(p=>p.UnitPrice)”实现

像数据库中order by 降序:

通过 “对象.OrderByDescending(p=>p.UnitPrice)”实现

像数据库中order by UnitPrice desc,Title asc:

通过 ”对象.OrderByDescending(p=>p.UnitPrice).ThenBy(p=>p.Title)”

反过来则是: ”对象.OrderBy(p=>p.UnitPrice).ThenByDescending(p=>p.Title)”

4.组函数:

var max = books.Where(p => p.CategoryId == 1001).Max(p => p.UnitPrice);

var min = books.Min(p => p.UnitPrice);

var count = books.Count( );

var avg = books.Average(p => p.UnitPrice);

var sum = books.Sum(p => p.UnitPrice);

注意,上面这些获得的东西,不是对象,是单个值

5. GROUP BY函数

// select categoryid,max(unitpirce) from books group by categoryid having max(unitprice)>50

var list6 = books.GroupBy(p => p.CategoryId).Where(p=>p.Max(q=>q.UnitPrice)>50);

foreach (var item in list6)

{

Response.Write(string.Format("

  • 类别编号:{0},最高价{1}
  • ",

item.Key,item.Max(p=>p.UnitPrice)));

}

6. TOP函数

//取一个范围 如3,5

var list7 = books.Skip(2).Take(3).Select(p => new { p.Title, p.CategoryId,  p.UnitPrice });

// select top 5

var list7 = books.Take(5).OrderByDescending(p => p.UnitPrice)

.Select(p => new { p.CategoryId, p.UnitPrice, p.Title, p.Author });

7.union 函数

books.Where(p => p.CategoryId == 1001).Select(p => new { p.CategoryId, p.UnitPrice, p.Title, p.Author }).Union(books.Where(p => p.CategoryId == 1002).Select(p => new { p.CategoryId, p.UnitPrice, p.Title, p.Author }));

这里的Select子句中的列需对应,跟数据库中是一样的

8.Join方法,用于实现数据库中双表连接查询

//select a.title,a.unitprice,a.categoryid,b.id,b.name from books a,category b

//where a.categoryid=b.id and b.name=‘数据库’

books.Join(cates.Where(m => m.Name == "数据库"),p => p.CategoryId, q => q.ID, (a, b) => new { a.Title, a.UnitPrice, a.CategoryId, b.ID, b.Name });

说明:

Join()方法的调用对象类似于在SQL语句中第一张表的表名

而Join()方法的第一个形参是第二张表表名的Where条件

Join()方法的第二和第三个参数分别表示第一张表与第二张表的关联字段

Join()方法的第四个参数表示从两表中需要获取的字段,(a, b)分别表示第一张表和第二张表

posted on 2014-01-29 12:20 bloodyboy 阅读(...) 评论(...) 编辑 收藏

转载于:https://www.cnblogs.com/bloodyboy/p/3536129.html

LAMBDA表达式常用写法相关推荐

  1. .NET笔记系列:LAMBDA表达式常用写法

    这里主要是将数据库中的常用操作用LAMBDA表达式重新表示了下,用法不多,但相对较常用,等有时间了还会扩展,并将查询语句及LINQ到时也一并重新整理下: 1.select语句:books.Select ...

  2. Spring切点表达式常用写法

    任意公共方法的执行: execution(public * *(..)) 任何一个名字以 set 开始的方法的执行: execution(* set*(..)) AccountService 接口定义 ...

  3. Lambda表达式常用代码示例

    Lambda表达式常用代码示例 2017-10-24 目录 1 Lambda表达式是什么 2 Lambda表达式语法 3 函数式接口是什么   3.1 常用函数式接口 4 Lambdas和Stream ...

  4. Lambda01 编程范式、lambda表达式与匿名内部类、函数式接口、lambda表达式的写法...

    1 编程范式 主要的编程范式有三种:命令式编程,声明式编程和函数式编程. 1.1 命令式编程 关注计算机执行的步骤,就是告诉计算机先做什么后做什么 1.2 声明式编程 表达程序的执行逻辑,就是告诉计算 ...

  5. Spring切入点表达式常用写法

    Spring切入点表达式常用写法 自从使用AspectJ风格切面配置,使得Spring的切面配置大大简化,但是AspectJ是另外一个开源项目,其规则表达式的语法也稍稍有些怪异. 下面给出一些常见示例 ...

  6. LAMBDA表达式常用 (全)

    这里主要是将数据库中的常用操作用LAMBDA表达式重新表示了下,用法不多,但相对较常用,等有时间了还会扩展,并将查询语句及LINQ到时也一并重新整理下: 1.select语句:books.Select ...

  7. java lambda例子_Java lambda 表达式常用示例

    实体类 package com.lkb.java_lambda.dto; import lombok.Data; /** * @program: java_lambda * @description: ...

  8. 五、Java中常用的API(通过包进行分类)————异常、多线程和Lambda表达式

    之前已经介绍了java.lang包下的相关类,今天将要补充两个常用的API:java.lang.Throwable和java.lang.Thread 一.异常(java.lang.Throwable) ...

  9. java8 lambda 排序算法,Java8中排序算法比较器的三种写法(使用lambda表达式实现Comparator比较器)...

    在涉及到数组, 集合等这些地方经常会需要用到排序算法, 在Java中的Collections类中有sort方法, 除了需要传入一个Comparator比较器, 或者需要排序的类实现了Comparabl ...

  10. 面试官系统精讲Java源码及大厂真题 - 42 常用的 Lambda 表达式使用场景解析和应用

    42 常用的 Lambda 表达式使用场景解析和应用 引导语 我们日常工作中,Lambda 使用比较多的场景,就是 List 或 Map 下的 Lambda 流操作,往往几行代码可以帮助我们实现多层 ...

最新文章

  1. 17.Java5的Exchanger同步工具
  2. CF535C Tavas and Karafs 二分 + 结论
  3. malloc/free 和 new/delete的联系和区别
  4. tcp 发送 最大数据量_网络基础知识夯实总结(三):TCP协议
  5. SecureCRT上传bash: rz: command not found
  6. 测试与 debug 心得
  7. 求解偏微分方程开源有限元软件deal.II学习--Step 6
  8. (转)金融从业人员的核心竞争力在哪里?
  9. Listary一款不只是程序员需要的软件
  10. 本科论文房地产公司财务风险评价与控制研究
  11. 三星堆的青铜机器人_三星堆“青铜纵目人像”到底是谁?专家终于讲出了真相...
  12. 微软亚洲研究院全球院友线上欢聚,共话新春
  13. 使用ServiceMonitor管理配置监控
  14. Static Single Assignment(SSA)
  15. 【超简便的Python】 提取两个列表的共同元素
  16. 03-Minisys-1的典型指令详解
  17. CC00070.bigdatajava——|Java循环结构.V09|——|Java.v09|双重for循环.v02|打印各种星星图案|
  18. 计算机鼠标不显示桌面,电脑开机后不显示桌面只有鼠标箭头,怎么回事
  19. Linux使用alias设置命令别名
  20. Java SE菜鸟之异常

热门文章

  1. oracle占位符怎么打,oracle所支持的占位符是什么
  2. 菜鸟保税仓成全球商家进中国首选 秒级通关领先全球
  3. 未能加载文件或程序集什么原因
  4. 怎么在地图上标注自己的店铺
  5. php四六级报名考试源码,全国大学英语四六级考试报名官网
  6. 超级授权专业版 SuperSU Pro v2.68 简体中文版
  7. Canonical Address
  8. 自学简单编程可行吗?
  9. SOAP Action介绍
  10. 哈工程转专业计算机,2021年哈尔滨工程大学大一新生转专业及入学考试相关规定...