LINQ和Lambda表达式
前言
前段时间接触了一种新的表达式,但是不知道这个是什么意思,所以就先站在巨人的肩膀用了,现在听师哥说这种写法是Lambda表达式。我一直以为,这个Lambda表达式和LINQ查询有异曲同工之妙,可惜,这样想就大错特错了。
内容
LINQ表达式
定义
语言集成查询(Language Integrated Query),允许编写C#或者VB代码以查询数据库相同的方式操作内存数据。(其实个人认为和我们平常写的SQL语句功能类似)
- LINQ写法
From临时变量in实现IEnumerable<T>接口对象
Where表达式
[orderby条件]
[groupby条件]
Select临时变量中被查询的值
例子:
//查询家是London的顾客;
var expr=
from c in Customers
where c.City=="London"
select c;
//SQL写法
var expr =
select * from Customers where City="London";
- LINQ优点(来自百科)
1、无需复杂学习过程即可上手;
2、编写更少的代码即可创建完整应用;
3、更快开发错误更少的应用程序;
4、无需求助奇怪的编程技巧就可以合并数据源;(这不理解呢!)
5、能够大幅减少过程控制语句代码块,使代码的可读性和可维护性大幅度提高;
6、任何对象或数据源都可以定制实现LINQ适配器,为数据交互带来真正方便。
- LINQ应用场景
LINQ支持数据源有SQL Server、Oracle、XML(标准通用标记语言)以及内存中的数据集合。
Lambda表达式
定义
Lambda表达式“(Lambda Expression)”是一个匿名函数。
- C#表达式
形参列表=>函数体(运算符读为goes to)
函数体多用一条语句的可用大括号括起来。
- 在LINQ中的Lambda表达式是我们常用的使用方法:
例子
//查询家是London的顾客;
var expr=>
from c in Customers
where c.City="London"
select c;
小结
查了查,然后总结了一下,感觉LINQ和表达式其实在原有的数据库查询上还是有改进的,因为我们写的SQL语句,在执行查询的时候,就是先执行from后面的,然后根据条件选择出来,这种LINQ查询的写法正好类似于后台数据查询执行顺序,在一定程度上确实比较实用;Lambda表达式,匿名函数,没有函数名称的一种函数,其实这个外部方法没有权限访问Lambda表达式内部引入的变量,内部的可以访问外部的,这个和JS里面的闭包函数很相似,这在一定程度上保护了这种情况下的变量。
感谢您的宝贵时间······
LINQ和Lambda表达式的更多相关文章
- LInq 与lambda表达式
LInq 与lambda表达式 LinQ是我们常用的技术之一.因为我们绕不开的要对数据进行一系列的调整,如 排序. 条件筛选.求和.分组.多表联接 等等. lambda则是我们常用的语法糖,配合lin ...
- 使用LINQ、Lambda 表达式 、委托快速比较两个集合,找出需要新增、修改、删除的对象
本文需要对C#里的LINQ.Lambda 表达式 .委托有一定了解. 在工作中,经常遇到需要对比两个集合的场景,如: 页面集合数据修改,需要保存到数据库 全量同步上游数据到本系统数据库 在这些场景中, ...
- SQL、Linq和Lambda表达式 的关系
首先说说这三者完全是三种不同的东西,SQL是结构化查询语言(Structured Query Language)简称,这大家再熟悉不过了,下面主要介绍LINQ和Lambda表达式的基本概念以及同一查询 ...
- c#封装DBHelper类 c# 图片加水印 (摘)C#生成随机数的三种方法 使用LINQ、Lambda 表达式 、委托快速比较两个集合,找出需要新增、修改、删除的对象 c# 制作正方形图片 JavaScript 事件循环及异步原理(完全指北)
c#封装DBHelper类 public enum EffentNextType { /// <summary> /// 对其他语句无任何影响 /// </summary> ...
- 动态LINQ(Lambda表达式)构建
using System; using System.Collections.Generic; using System.Linq; using System.Linq.Expressions; us ...
- LINQ使用Lambda表达式选择几列
学习LINQ的Lambda的表达式,尝试从数据集合中,选择其中几列. 创建一个model: source code: namespace Insus.NET.Models { public class ...
- Linq之Lambda表达式
一 什么是LINQ? LINQ即Language Integrated Query(语言集成查询),LINQ是集成到C#和Visual Basic.NET这些语言中用于提供查询数据能力的一个新特性. ...
- Linq之Lambda表达式初步认识
目录 写在前面 匿名方法 一个例子 Lambda 定义 一个例子 总结 参考文章 写在前面 元旦三天在家闲着无事,就看了看Linq的相关内容,也准备系统的学习一下,作为学习Linq的前奏,还是先得说说 ...
- 【2017-06-01】Linq基础+Lambda表达式实现对数据库的增删改查
一.Linq to sql 类 高集成化的数据库访问技术 使用Linq可以代替之前的Ado.Net.省去了自己敲代码的实体类和数据访问类的大量工作. 实体类: 添加一个Linq to sql 类 -- ...
- Linq基础+Lambda表达式对数据库的增删改及简单查询
一.Linq to sql 类 高集成化的数据库访问技术 使用Linq可以代替之前的Ado.Net,省去了自己敲代码的实体类和数据访问类的大量工作 实体类: 添加一个Linq to sql 类 --- ...
随机推荐
- 引用com.sencha.gxt.ui.GXT加载错误解决方案
环境GWT2.7+GXT4.0 <inherits name='com.sencha.gxt.ui.GXT' /> 出现加载错误 Loading inherited module 'com ...
- Python:函数变量的使用
1.上层函数不能直接使用其嵌套函数的变量: def func1(x, y): z = x + y def func2(): m = 3 z += m return z print(func1(1, 2 ...
- MongoDB优化之一:常见优化方法
常用性能优化方案 创建索引 限定返回结果数 只查询使用到的字段 采用capped collection 采用Server Side Code Execution 使用Hint,强制使用索引 Hint ...
- appium运行时启动失败
1.检查服务是否开启 2.简单Android设备是否连接成功 3.检查4723端口是否被占用: netstat -ano|findstr '4723' 查到被占用后,找到pid,进入任务管理器查看该p ...
- rsync mac->windows openssh
rsync -azvP --progress -e "ssh -p 6666" /Users/codar/360\344\272\221\347\233\230/ghld/ rsy ...
- The connection to adb is down and a sever error has occured的解决
1. 打开任务管理器,关掉豌豆夹等手机助手 2. 打开命令行,切换到adb所在目录,如:C:\Users\Jubincn\Downloads\adt-bundle-windows-x86_64-201 ...
- Qt creator 使用qwt
.pro中添加 LIBS += -L”C:\Qt\Qt5.3.2\5.3\msvc2013_opengl\lib” -lqwt INCLUDEPATH += "C:\Qt\Qt5.3.2\5 ...
- Markdown简要规则
We believe that writing is about content, about what you want to say – not about fancy formatting. 我 ...
- 使用Aspectj 的配置文件方式进行aop操作
- ROS Learning-024 (提高篇-002) rviz的安装和使用
ROS 提高篇-002 - rviz 的安装和使用 我使用的虚拟机软件:VMware Workstation 11 使用的Ubuntu系统:Ubuntu 14.04.4 LTS ROS 版本:ROS ...