LINQ查询表达式和LAMBDA点标记方法基础
在上一篇文章中,我们介绍了LINQ的一些基本用法,这一篇我们来看下另一种更简洁更优雅的表达式,Lambda表达式,也可以叫做点标记方法。
相信大家在实际工作中都用到过这两种方式,下面我们还是用实例来看下两种表达式的一些基本用法。
首先还是创建一个C#控制台程序,准备测试数据,创建两个类,Product产品类和Category类别类,每个产品分配一个类别。
public class Category
{
public int CategoryID { get; set; }
public string CategoryName { get; set; }
} public class Product
{
public int ProductID { get; set; }
public string ProductName { get; set; }
public int CategoryID { get; set; }
public int Count { get; set; }
public string Description { get; set; }
}
接着创建一些Category类型和Product类型的测试数组列表。
Category[] categories = new Category[]{
new Category{CategoryID=,CategoryName="TOYOTA"},
new Category{CategoryID=,CategoryName="BMW"},
new Category{CategoryID=,CategoryName="BENZ"},
new Category{CategoryID=,CategoryName="HONDA"},
new Category{CategoryID=,CategoryName="LEXUS"}
};
Product[] products = new Product[]{
new Product{ProductID=,ProductName="Car1",CategoryID=,Count=,Description="TOYOTA Car"},
new Product{ProductID=,ProductName="Car2",CategoryID=,Count=,Description="TOYOTA SUV"},
new Product{ProductID=,ProductName="Car3",CategoryID=,Count=,Description="BMW Car"},
new Product{ProductID=,ProductName="Car4",CategoryID=,Count=,Description="BMW SUV"},
new Product{ProductID=,ProductName="Car5",CategoryID=,Count=,Description="BENZ Car"},
new Product{ProductID=,ProductName="Car6",CategoryID=,Count=,Description="HONDA Car"},
new Product{ProductID=,ProductName="Car7",CategoryID=,Count=,Description="LEXUS Car"},
new Product{ProductID=,ProductName="Car8",CategoryID=,Count=,Description="LEXUS SUV"}
};
1.查询产品列表中所有记录的ProductName,Count,Description列。(select)
// LINQ
var productQuery1 = from p in products
select new
{
p.ProductName,
p.Count,
p.Description
}; Console.WriteLine("LINQ---");
foreach(var item in productQuery1)
{
Console.WriteLine("Product Name: {0} , Count: {1} , Description: {2}", item.ProductName, item.Count, item.Description);
} // LAMBDA
var productQuery2 = products.Select(p => new
{
ProductName = p.ProductName,
Count = p.Count,
Description = p.Description
}); Console.WriteLine("LAMBDA---");
foreach (var item in productQuery2)
{
Console.WriteLine("Product Name: {0} , Count: {1} , Description: {2}", item.ProductName, item.Count, item.Description);
}

2.查询产品列表中Count大于5的记录。(where)
// LINQ
var productQuery1 = from p in products
where p.Count >
select p; Console.WriteLine("LINQ---");
foreach (var item in productQuery1)
{
Console.WriteLine(item.ProductName);
} // LAMBDA
var productQuery2 = products.Where(P => P.Count > ); Console.WriteLine("LAMBDA---");
foreach (var item in productQuery2)
{
Console.WriteLine(item.ProductName);
}

3.查找产品列表中类别为TOYOTA,BENZ,LEXUS的记录。(where / contains)
// LINQ
var productQuery1 = from p in products
where (new int[] { ,,}).Contains(p.CategoryID)
select p; Console.WriteLine("LINQ---");
foreach (var item in productQuery1)
{
Console.WriteLine("Product Name: {0} , Category ID: {1} , Description: {2}", item.ProductName, item.CategoryID, item.Description);
} // LAMBDA
var productQuery2 = products.Where(p => new int[] { , , }.Contains(p.CategoryID)); Console.WriteLine("LAMBDA---");
foreach (var item in productQuery2)
{
Console.WriteLine("Product Name: {0} , Category ID: {1} , Description: {2}", item.ProductName, item.CategoryID, item.Description);
}

4.查找产品列表中类别为TOYOTA,LEXUS的记录,并且结果按产品数量Count降序排列。(where / orderby)
// LINQ
var productQuery1 = from p in products
where p.CategoryID== || p.CategoryID==
orderby p.Count descending
select p; Console.WriteLine("LINQ---");
foreach (var item in productQuery1)
{
Console.WriteLine("Product Name: {0} , Category ID: {1} , Count: {2} , Description: {3}", item.ProductName, item.CategoryID, item.Count,item.Description);
} // LAMBDA
var productQuery2 = products.Where(p => (p.CategoryID == || p.CategoryID == )).OrderByDescending(p => p.Count); Console.WriteLine("LAMBDA---");
foreach (var item in productQuery2)
{
Console.WriteLine("Product Name: {0} , Category ID: {1} , Count: {2} , Description: {3}", item.ProductName, item.CategoryID, item.Count, item.Description);
}

5.产品列表和类别列表联合查询。(join)
// LINQ
var productJoinCategoryQuery1 = from p in products
join c in categories
on p.CategoryID equals c.CategoryID
select new { p, c }; Console.WriteLine("LINQ---");
foreach (var item in productJoinCategoryQuery1)
{
Console.WriteLine("Product Name: {0} , Category Name: {1} , Count: {2} , Description: {3}", item.p.ProductName, item.c.CategoryName, item.p.Count, item.p.Description);
} // LAMBDA
var productJoinCategoryQuery2 = products.Join(categories,
p => p.CategoryID,
c => c.CategoryID,
(p, c) => new { p, c }); Console.WriteLine("LAMBDA---");
foreach (var item in productJoinCategoryQuery2)
{
Console.WriteLine("Product Name: {0} , Category Name: {1} , Count: {2} , Description: {3}", item.p.ProductName, item.c.CategoryName, item.p.Count, item.p.Description);
}

6.产品列表和类别列表分组联合查询。(join & group)
// LINQ
var productByCategoryResult1 = from c in categories
join p in products
on c.CategoryID equals p.CategoryID
into CategoryProducts
select new
{
c.CategoryName,
Products = CategoryProducts
}; Console.WriteLine("LINQ---");
foreach (var item in productByCategoryResult1)
{
Console.WriteLine("Category: {0}", item.CategoryName);
foreach (var product in item.Products)
{
Console.WriteLine("{0} ({1})", product.ProductName, product.Description);
}
Console.WriteLine();
} // LAMBDA
var productByCategoryResult2 = categories.GroupJoin(products,
c => c.CategoryID,
p => p.CategoryID,
(c, p) => new { c.CategoryName, Products = p }); Console.WriteLine("LAMBDA---");
foreach (var item in productByCategoryResult2)
{
Console.WriteLine("Category: {0}", item.CategoryName);
foreach (var product in item.Products)
{
Console.WriteLine("{0} ({1})", product.ProductName, product.Description);
}
Console.WriteLine();
}

7.LAMBDA的一些其他用法。
// LAMBDA 一些其他常用方法
// Min
var productQueryMin = products.Min(p => p.Count);
Console.WriteLine("Count Min: {0}", productQueryMin);
// Max
var productQueryMax = products.Max(p => p.Count);
Console.WriteLine("Count Max: {0}", productQueryMax);
// Average
var productQueryAverage = products.Average(p => p.Count);
Console.WriteLine("Count Average: {0}", productQueryAverage);
// Sum
var productQuerySum= products.Sum(p => p.Count);
Console.WriteLine("Count Sum: {0}", productQuerySum);
// Skip / Take
var productQueryPage = products.Skip().Take().Select(p => new { p.ProductName, p.Count, p.Description });
foreach (var item in productQueryPage)
{
Console.WriteLine("Product Name: {0} , Count: {1} , Description: {2}", item.ProductName, item.Count, item.Description);
}
// First (返回第一条记录,如果没有记录,则抛出异常)
var firstProduct = products.First();
// 此处查询的记录不存在,所以这行代码会抛出异常
var firstProductNull = products.Where(p => p.Count > ).First();
// FirstOrDefault (返回第一条记录,如果没有,则返回null)
var firstOrDefaultProduct = products.FirstOrDefault();
// 此处查询的记录不存在,所以这行代码返回null
var firstOrDefaultProductNull = products.Where(p => p.Count > ).FirstOrDefault();
// Single (返回集合中唯一的记录,如果大于或小于一条记录,则抛出异常,这行代码执行记录大于一条,所以会抛出异常)
var singleProduct = products.Single();
// 这行代码执行记录小于一条记录,所以也会抛出异常
var singleProductNull = products.Where(p => p.Count > ).SingleOrDefault();
好了,本篇就先到此,希望对你有所帮助,谢谢!
LINQ查询表达式和LAMBDA点标记方法基础的更多相关文章
- C# LINQ查询表达式用法对应Lambda表达式
C#编程语言非常优美,我个人还是非常赞同的.特别是在学习一段时间C#后发现确实在它的语法和美观度来说确实要比其它编程语言强一些(也可能是由于VS编译器的加持)用起来非常舒服,而且对于C#我觉得他最优美 ...
- LINQ查询表达式详解(2)——查询表达式的转换
简介 C#在执行LINQ查询表达式的时候,并不会指定其执行语义,而是将查询表达式转换为遵循查询表达式模式的方法的调用.具体而言,查询表达式将转换为以下名称的调用:Where.Select.Select ...
- [C#.NET 拾遗补漏]13:动态构建LINQ查询表达式
最近工作中遇到一个这样的需求:在某个列表查询功能中,可以选择某个数字列(如商品单价.当天销售额.当月销售额等),再选择 小于或等于 和 大于或等于 ,再填写一个待比较的数值,对数据进行查询过滤. 如果 ...
- Linq专题之创建Linq查询表达式
本节我们主要介绍一下如何创建查询集合类型,关系数据库类型,DataSet对象类型和XML类型的数据源的Linq查询表达式. 下面在实例代码ReadyCollectionData()函数创建了准备的数据 ...
- 2.3 LINQ查询表达式中 使用select子句 指定目标数据
本篇讲解LINQ查询的三种形式: 查询对象 自定义查询对象某个属性 查询匿名类型结果 [1.查询结果返回集合元素] 在LINQ查询中,select子句和from子句都是必备子句.LINQ查询表达式必须 ...
- LINQ查询表达式(1) - 查询表达式基础
LINQ包括五个部分:LINQto Objects.LINQ to DataSets.LINQ to SQL.LINQ to Entities.LINQ to XML. 什么是查询?它有什么用途? “ ...
- LINQ查询表达式---------let子句
LINQ查询表达式---------let子句 let子句创建一个范围变量来存储结果,变量被创建后,不能修改或把其他表达式的结果重新赋值给它.此范围变量可以再后续的LINQ子句中使用. class P ...
- LINQ查询表达式---------join子句
LINQ查询表达式---------join子句 join 子句接受两个源序列作为输入. 每个序列中的元素都必须是可以与另一个序列中的相应属性进行比较的属性,或者包含一个这样的属性. join子句使用 ...
- LINQ查询表达式---------orderby子句
LINQ查询表达式---------orderby子句 LINQ可以按元素的一个或多个属性对元素进行排序. class Program { public class PerInfo { public ...
随机推荐
- memcached命令和配置
转自:http://www.tuicool.com/articles/VJzAvuB 安装配置 首先,编译.安装.配置libevent库,执行如下命令: wget https://github.com ...
- STM32驱动AT24CXX系列芯片
AT24Cxx系列EEPROM是由美国Mcrochip公司出品,1-512K位的支持I2C总线数据传送协议的串行CMOS E2PROM,可用电擦除,可编程自定时写周期(包括自动擦除时间不超过10ms, ...
- 【转】C\C++代码优化的27个建议
1. 记住阿姆达尔定律: funccost是函数func运行时间百分比,funcspeedup是你优化函数的运行的系数. 所以,如果你优化了函数TriangleIntersect执行40%的运行时间, ...
- python threading模块中对于信号的抓取
最近的物联网智能网关(树莓派)项目中遇到这样一个问题:要从多个底层串口读取发来的数据,并且做出相应的处理,对于每个串口的数据的读取我能想到的可以采用两种方式: 一种是采用轮询串口的方式,例如每3s向每 ...
- HDU 3264 Open-air shopping malls ——(二分+圆交)
纯粹是为了改进牛吃草里的两圆交模板= =. 代码如下: #include <stdio.h> #include <algorithm> #include <string. ...
- 设置MyEclipse黑色主题背景
设置MyEclipse黑色主题背景 1. 下载 http://eclipsecolorthemes.org/ 看哪个合适直接点击进入, 下载右边的epf 2. 下载完成...打开myeclipse. ...
- mongodb更新数据
1. 获取当前时间: Calendar.getInstance().getTime(); 2. 更新数据: public void updateProcessLandLog(ProcessLandLo ...
- zend framework 配置连接数据库
Zend_Db_Adapter是zend frmaeword的数据库抽象层api.基于pdo, 你可以使用Zend_Db_Adapter连接和处理多种 数据库,包括:microsoft SQL ...
- MAC + java 环境配置
1. 下载安装 jdk 2. 配置环境 2.1. cd到目录 etc/profile 2.2. 使文件可读:chmod 666 profile model 2.3. 添加环境变量,要切换到etc目录: ...
- simplexml 对xml的增删改操作
simplexml 是php 处理xml 文件的一个方法,另一个是dom 处理,这里只说simplexml .目前php 处理xml 用的比较多,比较成熟的还是dom .但dom 在速度和代码量上还是 ...