LINQ查询操作符
- ·First - 返回集合中的第一个元素;不延迟
- ·FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值);不延迟
- ·Last - 返回集合中的最后一个元素;不延迟
- ·LastOrDefault - 返回集合中的最后一个元素(如果没有则返回默认值)
- ·ElementAt - 返回集合中指定索引的元素;不延迟
- ·ElementAtOrDefault - 返回集合中指定索引的元素(如果没有则返回默认值);不延迟
- ·Contains - 判断集合中是否包含有某一元素;不延迟
- ·Any - 判断集合中是否有元素满足某一条件;不延迟
- ·All - 判断集合中是否所有元素都满足某一条件;不延迟
- ·Count - 返回集合中的元素个数,返回int;不延迟
- ·LongCount - 返回集合中的元素个数,返回long;不延迟
- ·Sum - 集合应为数字类型集合,求其和;不延迟
- ·Min - 返回集合的最小值;不延迟
- ·Max - 返回集合的最大值;不延迟
- ·Average - 集合应为数字类型集合,求其平均值;不延迟
- ·Aggregate - 根据输入的表达式获取一个聚合值;不延迟
- ·Cast - 将集合转换为强类型集合;延迟
- ·DefaultIfEmpty - 查询结果为空则返回默认值;延迟
- ·SequenceEqual - 判断两个集合是否相同;不延迟
- ·OfType - 过滤集合中的指定类型;延迟
- ·ToArray - 将集合转换为数组;不延迟
- ·ToList - 将集合转换为List<T>集合;不延迟
- ·ToDictionary - 将集合转换为<K, V>集合;不延迟
Summary3.aspx.cs
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Xml.Linq; using System.Collections.Generic;
using DAL; public partial class LINQ_Summary3 : System.Web.UI.Page
{
NorthwindDataContext _ctx = new NorthwindDataContext();
string[] _ary = null; protected void Page_Load(object sender, EventArgs e)
{
_ary = new string[] { "asp.net", "csharp", "xhtml", "css", "javascript",
"wcf", "wpf", "silverlight", "linq", "wf",
"sqlserver", "asp.net ajax", "ssis", "ssas", "ssrs" }; // First - 返回集合中的第一个元素;不延迟
// FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值);不延迟
Summary_First_FirstOrDefault(); // Last - 返回集合中的最后一个元素;不延迟
// LastOrDefault - 返回集合中的最后一个元素(如果没有则返回默认值)
Summary_Last_LastOrDefault(); // ElementAt - 返回集合中指定索引的元素;不延迟
// ElementAtOrDefault - 返回集合中指定索引的元素(如果没有则返回默认值);不延迟
Summary_ElementAt_ElementAtOrDefault(); // Contains - 判断集合中是否包含有某一元素;不延迟
Summary_Contains(); // Any - 判断集合中是否有元素满足某一条件;不延迟
Summary_Any(); // All - 判断集合中是否所有元素都满足某一条件;不延迟
Summary_All(); // Count - 返回集合中的元素个数,返回int;不延迟
// LongCount - 返回集合中的元素个数,返回long;不延迟
Summary_Count_LongCount(); // Sum - 集合应为数字类型集合,求其和;不延迟
Summary_Sum(); // Min - 返回集合的最小值;不延迟
Summary_Min(); // Max - 返回集合的最大值;不延迟
Summary_Max(); // Average - 集合应为数字类型集合,求其平均值;不延迟
Summary_Average(); // Aggregate - 根据输入的表达式获取一个聚合值;不延迟
Summary_Aggregate(); // Cast - 将集合转换为强类型集合;延迟
Summary_Cast(); // DefaultIfEmpty - 查询结果为空则返回默认值;延迟
Summary_DefaultIfEmpty(); // SequenceEqual - 判断两个集合是否相同;不延迟
Summary_SequenceEqual(); // OfType - 过滤集合中的指定类型;延迟
Summary_OfType(); // ToArray - 将集合转换为数组;不延迟
Summary_ToArray(); // ToList - 将集合转换为List<T>集合;不延迟
Summary_ToList(); // ToDictionary - 将集合转换为<K, V>集合;不延迟
Summary_ToDictionary();
}
}
First - 返回集合中的第一个元素;不延迟
FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值);不延迟
/**//// <summary>
/// First - 返回集合中的第一个元素;不延迟
/// FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值);不延迟
/// </summary>
void Summary_First_FirstOrDefault()
{
string s = (from a in _ary
select a).First(a => a.StartsWith("s"));
// string s = (from a in _ary
// select a).FirstOrDefault(a => a.StartsWith("xxx"));
// s == null result.InnerHtml += s + "<br />";
result.InnerHtml += "<br />";
}运行结果
silverlight Last - 返回集合中的最后一个元素;不延迟
LastOrDefault - 返回集合中的最后一个元素(如果没有则返回默认值)
/**//// <summary>
/// Last - 返回集合中的最后一个元素;不延迟
/// LastOrDefault - 返回集合中的最后一个元素(如果没有则返回默认值)
/// </summary>
void Summary_Last_LastOrDefault()
{
string s = (from a in _ary
select a).Last(a => a.StartsWith("s"));
// string s = (from a in _ary
// select a).LastOrDefault(a => a.StartsWith("sss"));
// s == null result.InnerHtml += s + "<br />";
result.InnerHtml += "<br />";
}运行结果
ssrs ElementAt - 返回集合中指定索引的元素;不延迟
ElementAtOrDefault - 返回集合中指定索引的元素(如果没有则返回默认值);不延迟
/**//// <summary>
/// ElementAt - 返回集合中指定索引的元素;不延迟
/// ElementAtOrDefault - 返回集合中指定索引的元素(如果没有则返回默认值);不延迟
/// </summary>
void Summary_ElementAt_ElementAtOrDefault()
{
string s = (from a in _ary
select a).ElementAt();
// string s = (from a in _ary
// select a).ElementAtOrDefault(1000);
// s == null result.InnerHtml += s + "<br />";
result.InnerHtml += "<br />";
}运行结果
css Contains - 判断集合中是否包含有某一元素;不延迟
/**//// <summary>
/// Contains - 判断集合中是否包含有某一元素;不延迟
/// </summary>
void Summary_Contains()
{
bool b = (from a in _ary
select a).Contains("javascript"); result.InnerHtml += b.ToString() + "<br />";
result.InnerHtml += "<br />";
}运行结果
True Any - 判断集合中是否有元素满足某一条件;不延迟
/**//// <summary>
/// Any - 判断集合中是否有元素满足某一条件;不延迟
/// </summary>
void Summary_Any()
{
bool b = (from a in _ary
select a).Any(p => p.Length > ); result.InnerHtml += b.ToString() + "<br />";
result.InnerHtml += "<br />";
}运行结果
True All - 判断集合中是否所有元素都满足某一条件;不延迟
/**//// <summary>
/// All - 判断集合中是否所有元素都满足某一条件;不延迟
/// </summary>
void Summary_All()
{
bool b = (from a in _ary
select a).All(p => p.Length > ); result.InnerHtml += b.ToString() + "<br />";
result.InnerHtml += "<br />";
}运行结果
False Count - 返回集合中的元素个数,返回int;不延迟
LongCount - 返回集合中的元素个数,返回long;不延迟
/**//// <summary>
/// Count - 返回集合中的元素个数,返回int;不延迟
/// LongCount - 返回集合中的元素个数,返回long;不延迟
/// </summary>
void Summary_Count_LongCount()
{
int i = (from a in _ary
select a).Count(p => p.Length > );
// long i = (from a in _ary
// select a).LongCount(p => p.Length > 10); result.InnerHtml += i.ToString() + "<br />";
result.InnerHtml += "<br />";
}运行结果 Sum - 集合应为数字类型集合,求其和;不延迟
/**//// <summary>
/// Sum - 集合应为数字类型集合,求其和;不延迟
/// </summary>
void Summary_Sum()
{
int i = (from a in _ary
select a.Length).Sum(); result.InnerHtml += i.ToString() + "<br />";
result.InnerHtml += "<br />";
}运行结果 Min - 返回集合的最小值;不延迟
/**//// <summary>
/// Min - 返回集合的最小值;不延迟
/// </summary>
void Summary_Min()
{
int i = (from a in _ary
select a.Length).Min(); result.InnerHtml += i.ToString() + "<br />";
result.InnerHtml += "<br />";
}运行结果 Max - 返回集合的最大值;不延迟
/**//// <summary>
/// Max - 返回集合的最大值;不延迟
/// </summary>
void Summary_Max()
{
int i = (from a in _ary
select a.Length).Max(); result.InnerHtml += i.ToString() + "<br />";
result.InnerHtml += "<br />";
}运行结果 Average - 集合应为数字类型集合,求其平均值;不延迟
/**//// <summary>
/// Average - 集合应为数字类型集合,求其平均值;不延迟
/// </summary>
void Summary_Average()
{
double d = (from a in _ary
select a.Length).Average(); result.InnerHtml += d.ToString() + "<br />";
result.InnerHtml += "<br />";
}运行结果
5.8 Aggregate - 根据输入的表达式获取一个聚合值;不延迟
/**//// <summary>
/// Aggregate - 根据输入的表达式获取一个聚合值;不延迟
/// </summary>
void Summary_Aggregate()
{
// 以下算法的Aggregate相当于Sum
double d = (from a in _ary
select a.Length).Aggregate((x, y) => x + y); result.InnerHtml += d.ToString() + "<br />";
result.InnerHtml += "<br />";
}运行结果 Cast - 将集合转换为强类型集合;延迟
/**//// <summary>
/// Cast - 将集合转换为强类型集合;延迟
/// </summary>
void Summary_Cast()
{
ArrayList al = new ArrayList();
al.Add("asp.net");
al.Add("csharp");
al.Add("xhtml"); var list = al.Cast<string>(); foreach (string s in list)
{
result.InnerHtml += s + "<br />";
}
result.InnerHtml += "<br />";
}运行结果
asp.net
csharp
xhtml DefaultIfEmpty - 查询结果为空则返回默认值;延迟
/**//// <summary>
/// DefaultIfEmpty - 查询结果为空则返回默认值;延迟
/// </summary>
void Summary_DefaultIfEmpty()
{
var list = (from a in _ary
where a.Length >
select a).DefaultIfEmpty("xxx"); foreach (string s in list)
{
result.InnerHtml += s + "<br />";
}
result.InnerHtml += "<br />";
}运行结果
xxx SequenceEqual - 判断两个集合是否相同;不延迟
/**//// <summary>
/// SequenceEqual - 判断两个集合是否相同;不延迟
/// </summary>
void Summary_SequenceEqual()
{
bool b = (from a in _ary
where a.Length >
select a).SequenceEqual(from a in _ary
where a.Length >
select a); result.InnerHtml += b.ToString() + "<br />";
result.InnerHtml += "<br />";
}运行结果
True OfType - 过滤集合中的指定类型;延迟
/**//// <summary>
/// OfType - 过滤集合中的指定类型;延迟
/// </summary>
void Summary_OfType()
{
object[] objects = { , "a", , "b", , "c" }; var list = objects.OfType<string>(); foreach (string s in list)
{
result.InnerHtml += s + "<br />";
}
result.InnerHtml += "<br />";
}运行结果
a
b
c ToArray - 将集合转换为数组;不延迟
/**//// <summary>
/// ToArray - 将集合转换为数组;不延迟
/// </summary>
void Summary_ToArray()
{
string[] ary = (from p in _ctx.Products
where p.ProductName.Length >
select p.ProductName).ToArray(); foreach (string s in ary)
{
result.InnerHtml += s + "<br />";
}
result.InnerHtml += "<br />";
}运行结果
Jack's New England Clam Chowder
Louisiana Fiery Hot Pepper Sauce
Original Frankfurter grüne So?e
Uncle Bob's Organic Dried Pears ToList - 将集合转换为List<T>集合;不延迟
/**//// <summary>
/// ToList - 将集合转换为List<T>集合;不延迟
/// </summary>
void Summary_ToList()
{
var list = (from a in _ary
where a.Length >
select a).ToList(); foreach (string s in list)
{
result.InnerHtml += s + "<br />";
}
result.InnerHtml += "<br />";
}运行结果
silverlight
asp.net ajax ToDictionary - 将集合转换为<K, V>集合;不延迟
/**//// <summary>
/// ToDictionary - 将集合转换为<K, V>集合;不延迟
/// </summary>
void Summary_ToDictionary()
{
var dic = (from p in _ctx.Products
where p.ProductName.Length >
select p).ToDictionary(p => p.ProductID); foreach (var p in dic)
{
result.InnerHtml += p.Key + ":" + p.Value.ProductName + "<br />";
}
result.InnerHtml += "<br />";
}运行结果
:Uncle Bob's Organic Dried Pears
:Jack's New England Clam Chowder
:Louisiana Fiery Hot Pepper Sauce
:Original Frankfurter grüne So?e
LINQ查询操作符的更多相关文章
- .NET 3.5(5) - LINQ查询操作符之Select、Where、OrderBy、OrderByDescending
.NET 3.5(5) - LINQ查询操作符之Select.Where.OrderBy.OrderByDescending 介绍 ·Select - Select选择:延迟 ·Where ...
- LINQ查询操作符之Select、Where、OrderBy、OrderByDescending、GroupBy、Join、GroupJoin及其对应的查询语法
介绍 ·Select - Select选择:延迟 ·Where - Where查询:延迟 ·OrderBy - 按指定表达式对集合正序排序:延迟 ·OrderByDescend ...
- LINQ查询操作符 LINQ学习第二篇[转]
一.投影操作符 1. Select Select操作符对单个序列或集合中的值进行投影.下面的示例中使用select从序列中返回Employee表的所有列: using (NorthwindDataCo ...
- LINQ查询操作符 LINQ学习第二篇
一.投影操作符 1. Select Select操作符对单个序列或集合中的值进行投影.下面的示例中使用select从序列中返回Employee表的所有列: using (NorthwindDataCo ...
- LINQ查询操作符之First、FirstOrDefault、Last、LastOrDefault、ElementAt、ElementAtOrDefault、Contains、Any、All、Coun
·First - 返回集合中的第一个元素:不延迟 ·FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值):不延迟 ·Last - 返回集合中的最后一个元素:不延迟 ·Las ...
- C#编程(六十二)---------LINQ标准的查询操作符
LINQ标准的查询操作符 首先我们来看一下LINQ的操作符,可根据查询操作符的操作”类型”进行分类,如把它们分成投影,限制,排序,联接,分组,串联,聚合,集合,生成,转换,元素,相等,量词,分割等. ...
- 转linq中的Single()、First()、Take(1) LINQ 标准的查询操作符 排序 orderby、thenby、Take
Single():操作一个集合,同时强要求只有一个对象匹配,并返回这一个. First():操作一个集合,可以有多个对象匹配,但是只返回第一个. Take(1):操作一个集合,可以有对个对象匹配,单只 ...
- LinQ实战学习笔记(三) 序列,查询操作符,查询表达式,表达式树
序列 延迟查询执行 查询操作符 查询表达式 表达式树 (一) 序列 先上一段代码, 这段代码使用扩展方法实现下面的要求: 取进程列表,进行过滤(取大于10M的进程) 列表进行排序(按内存占用) 只保留 ...
- LINQ标准查询操作符详解(转)
一. 关于LINQ LINQ 英文全称是“Language-Integrated Query”,中文为“语言集成查询”,它是微软首席架构师.Delphi 之父和C# 之父——Anders ...
随机推荐
- SAP S4CRM 1811 服务订单API介绍
Jerry在今年2月28日,SAP Customer Management for S/4HANA 1.0正式问世这个具有纪念意义的日子,同时发布了中英文版的博客进行介绍. 英文版发在SAP社区上,至 ...
- CRM订单状态的Open, In process和Completed这些条目是从哪里来的
Service Order的状态字段里的这些字段从哪里带出来的?我们可能会想当然的认为是从后台配的Status profile里带出来的.事实并非如此. 这个transaction type根本没有分 ...
- Android进阶笔记11:ListView篇之ListView性能优化
1. 首先思考一个问题ListView如何才能提高效率 ? 当convertView为空时候,用setTag()方法为每个View绑定一个存放控件的ViewHolder对象.当convertView不 ...
- (第六场)Singing Contest 【模拟】
题目链接:https://www.nowcoder.com/acm/contest/144/A 标题:A.Singing Contest | 时间限制:1 秒 | 内存限制:256M Jigglypu ...
- 清除IE地址栏中的历史网址
实现效果: 知识运用: RegistryKey类的GetValueNames和DeleteValue方法 实现代码: private void button1_Click(object sender, ...
- ROS编译工作区缺少cv_bridge的问题解决
cv_bridge是OpenCV与ROS之间的格式转换桥梁,编译工作区时遇到报错(目标不存在),直接将cv_bridge包复制到指定的目录即可. 下载地址:https://github.com/ros ...
- 【luogu P2194 HXY烧情侣】 题解
题目链接:https://www.luogu.org/problemnew/show/P2194 第一问:缩点并且统计其强连通分量里的最小耗费.把所有强连通分量的最小耗费加起来. 第二问:统计在每个强 ...
- 【luoguP1238】【NOIP2014】生活大爆炸版剪刀石头布
生活大爆炸版剪刀石头布 ——[传送门] 这道题可以原原本本地说得上是一道水题了,通过判断两人的出拳不同给分然后统计输出.就是对于游戏得分 ...
- Android学习笔记_69_android 支付宝之网页支付和快捷支付
参考资料: https://b.alipay.com/order/productDetail.htm?productId=2013080604609654 https://b.alipay.com/o ...
- HDU 1155 Bungee Jumping(物理题,动能公式,弹性势能公式,重力势能公式)
传送门: Bungee Jumping Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...