#region SQO (标准查询运算符) 方法
#region Where() Find() FindAll() FirstOrDefault()等方法
static void c01where()
{
var list = GetPigList();
//1.0 获取当前list集合中的符合条件的第一条数据
list.Sort((p, n) => p.Age - n.Age);
var pig = list.FirstOrDefault(p => p.Age > );
// pig.Say(); //2.0 first 获取当前list集合中的符合条件的第一条数据,如果没有找到则抛出异常
var pig1 = list.First(); //3.0 FindAll() 找到所有符合条件的数据,并全部返回
var newlist1 = list.FindAll(p => p.Age > ); //4.0 Find() 找到所有符合条件的数据,并返回第一条数据
var pig2 = list.Find(c => c.Id > );
//pig2.Say(); //5.0 Where()
//链式编程,从list集合中获取id==2的数据集合,通过foreach遍历新的数据集合,将数据打印出来
var pig3 = list.FindAll(p => p.Id == ).FirstOrDefault(); //和sql很像
//select * from list where age>2 and name like '%猪%'
//list.Where(p => p.Age > 2 && p.Name.Contains("猪")).ToList().ForEach(c => c.Say()); //lambda表达式的多条件或组合
list.Where(c => c.Id == || c.Id == ).ToList().ForEach(c => c.Say());
}
#endregion #region SQO 方法之 排序方法 OrderBy(), OrderByDescending()的使用
static void c01OrderBy()
{
var list = GetPigList();
//1.0 对list集合进行id的正序排列
list.OrderBy(c => c.Id).ToList().ForEach(c => c.Say()); //2.0 对list集合进行id的倒序排列
list.OrderByDescending(c => c.Id).ToList().ForEach(c => c.Say()); }
#endregion #region 链式编程
static void c01LinkCode()
{
var list = GetPigList();
list.Where(c => c.Id > ).Where(c => c.Age > ).OrderBy(c => c.Age).ToList().ForEach(c => Console.WriteLine(c.ToString()));
}
#endregion #region 多条件排序 ThenByDescending() ,ThenBy()
static void c01ThenBy()
{
var pigList = GetPigList();
//多条件排序:
//第一个排序条件可以使用OrderBy(),OrderByDescending()
//但是第二和以后的其他排序条件则必须使用ThenByDescending() ,ThenBy() 进行排序
// 语法和sql很像
pigList.OrderBy(c => c.TypeId).ThenByDescending(c => c.Id).ToList().ForEach(c => c.Say());
} #endregion #region Any() Count() 的用法
static void c01Other()
{
var list = GetPigList();
Console.WriteLine(list.Any(c => c.Age > )); //true
Console.WriteLine(list.Any(c => c.Id < )); //false Console.WriteLine(list.Count(c => c.Id < ));//
Console.WriteLine(list.Count(c => c.Age > ));//
}
#endregion #region Select() 投影方法的演示,作用:将一个集合投影到另外一个集合(重点)
static void c01Select()
{
//获取list集合中的id和name 作为一个新的集合返回
var list = GetPigList();
//利用Select() 将list集合中的id name 属性的值投影成匿名类返回
var newlist = list.Select(c => new { c.Id, c.Name }).ToList();
newlist.ForEach(c => Console.WriteLine(c.ToString()));
}
#endregion #region 利用Skip().Take()方法实现分页查询(重点)
static void c01GetListByPage()
{
int tcount = ;
GetListByPage(, , out tcount);
} static List<Pig> GetListByPage(int pageIndex, int pageSize, out int totalcount)
{
List<Pig> list = GetPigList();
//从集合中分页获取的数据
int skipCount = (pageIndex - ) * pageSize;
totalcount = list.Count();
//Skip:从集合中跳过指定的行数,Take:从跳过的指定行数下一行开始取指定的数据行数
return list.Skip(skipCount).Take(pageSize).ToList();
}
#endregion #region join() 两个集合连接查询,模拟实现sql中的inner join(交叉连接)
static void c01Join()
{
var piglist = GetPigList();
var typelist = GetTypeList(); //1.0 利用join方法将两个集合联合查询,最终得到piglist中的Id,name,同时获取typelist中的typename
//sql 语句:select c.Id,c.Name,t,TypeName from piglist c inner join typelist t on (c.TypeId=t.TypeId)
var newlist = piglist.Join(typelist, c => c.TypeId, t => t.TypeId, (c, t) => new { c.Id, c.Name, t.TypeName }).ToList();
newlist.ForEach(c => Console.WriteLine(c.ToString()));
}
#endregion #region GroupBy() 分组查询
static void c01GroupBy()
{
var list = GetPigList();
//1.0 调用GroupBy() 扩展方法 进行typeId的分组操作
//select TypeID from list group by TypeId
var groupList = list.GroupBy(c => c.TypeId).ToList();
groupList.ForEach(c =>
{
Console.WriteLine("分组号:" + c.Key + "------");
c.ToList().ForEach(d => d.Say());
});
}
#endregion #endregion

2.0 Linq To Object

#region 10.0 Linq to object (linq to sql, linq to xml)

        #region linq Where 的写法
static void c01LinqWhere()
{
var list = GetPigList();
//SQO写法
var newlist = list.Where(c => c.Age == && c.Name.Contains("猪"));
//linq的写法
//sql 语句:select c.Id,c.Name from list c where c.Age==12 and c.Name like '%猪%'
var newlist2 = (from c in list
where c.Age == && c.Name.Contains("猪")
select new { c.Id, c.Name }).ToList(); // newlist2.ForEach(c => Console.WriteLine(c.ToString())); var newlist3 = (from c in list
where c.Name.Contains("猪") && c.Id >
select new { c.Id, c.Name }).ToList();
newlist3.ForEach(c => Console.WriteLine(c.ToString())); }
#endregion #region join() 的linq写法
static void c01linqJoin()
{
var pigList = GetPigList();
var typeList = GetTypeList(); //linq的联表查询
(from c in pigList
join t in typeList
on c.TypeId equals t.TypeId
select new { c.Id, c.Name, t.TypeName }).ToList().ForEach(c => Console.WriteLine(c.ToString()));
}
#endregion #region GroupBy 的linq写法
static void c01LinqGroupBy()
{
var list = GetPigList();
(from c in list
group c by c.TypeId).ToList().ForEach(c =>
{
Console.WriteLine("---------分组号:" + c.Key + "---------");
c.ToList().ForEach(d => d.Say());
});
} #endregion #region Linq的排序写法
static void c01Sort()
{
var list = GetPigList(); (from c in list
orderby c.Id descending
orderby c.Age descending
select c).ToList().ForEach(c => Console.WriteLine(c.ToString()));
}
#endregion
#endregion

3.0 系统内置委托

#region 系统内置委托 & lambda表达式
#region 系统内置委托之 Predicate,接收一个泛型参数,返回一个bool值
/// <summary>
/// 系统内置委托之 Predicate,接收一个泛型参数,返回一个bool值
/// </summary>
static void C08Predicate()
{
List<Pig> list = GetPigList();
// 1.0.0查询当前年龄大于四岁的对象以新集合的形式返回
var newlist = list.FindAll(query); // 1.0.1 利用匿名委托来代替自定义方法query
var newlist2 = list.FindAll(delegate(Pig pig) { return pig.Age > ; }); //1.0.2 利用lambda表达式代替匿名委托 goes to
var newlist3 = list.FindAll(c => c.Age > );
}
#endregion #region 系统内置委托之 Action ,接受一个泛型参数,无返回值
/// <summary>
/// 系统内置委托之 Action ,接受一个泛型参数,无返回值
/// </summary>
static void c08Action()
{
var list = GetPigList();
list.ForEach(c => c.Say());
}
#endregion #region Comparison接收两个相同类型的参数,返回一个整数
/// <summary>
/// Comparison接收两个相同类型的参数,返回一个整数
/// </summary>
static void c08Comparison()
{
var list = GetPigList();
//1.0 对list进行排序
list.Sort((pre, next) => next.Id - pre.Id); //2.0 遍历输出
list.ForEach(c =>
c.Say());
}
#endregion #region 系统内置委托Func()
/// <summary>
/// 系统内置委托Func()
/// </summary>
static void c08Func()
{
var list = GetPigList();
//利用func<T,Result>进行集合数据筛选操作
var newlist = list.Where(c => c.Age > ).ToList();
newlist.ForEach(c => c.Say());
}
#endregion
#endregion

SQO (标准查询运算符)方法 & Linq To Object的更多相关文章

  1. .NET中那些所谓的新语法之四:标准查询运算符与LINQ

    开篇:在上一篇中,我们了解了预定义委托与Lambda表达式等所谓的新语法,这一篇我们继续征程,看看标准查询运算符和LINQ.标准查询运算符是定义在System.Linq.Enumerable类中的50 ...

  2. .NET LINQ标准查询运算符

    标准查询运算符概述      “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法. 大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了 IEnumerable<T> ...

  3. C#3.0新增功能09 LINQ 标准查询运算符 01 概述

    连载目录    [已更新最新开发文章,点击查看详细] 标准查询运算符 是组成 LINQ 模式的方法. 这些方法中的大多数都作用于序列:其中序列指其类型实现 IEnumerable<T> 接 ...

  4. C#3.0新增功能09 LINQ 标准查询运算符 03 按执行方式的分类

    连载目录    [已更新最新开发文章,点击查看详细] 标准查询运算符方法的 LINQ to Objects 实现主要通过两种方法之一执行:立即执行和延迟执行.使用延迟执行的查询运算符可以进一步分为两种 ...

  5. C#3.0新增功能09 LINQ 标准查询运算符 04 运算

    连载目录    [已更新最新开发文章,点击查看详细] 本篇主要介绍标准查询运算符的常用运算功能. 01 对数据排序 排序操作基于一个或多个属性对序列的元素进行排序. 第一个排序条件对元素执行主要排序. ...

  6. 十四、C# 支持标准查询运算符的集合接口

    支持标准查询运算符的集合接口. System.Linq.Enumeralbe类提供的一些常用的API 来执行集合处理 1.匿名类型 2.隐匿类型的局部变量 3.集合初始化器 4.集合 5.标准查询运算 ...

  7. “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法

    “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法.大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了IEnumerable<T> 接口或 IQueryable& ...

  8. LINQ标准查询运算符的执行方式-延时之流式处理

    linq的延时执行是指枚举时才去一个个生成结果元素. 流式处理是linq延时执行的一种,在生成元素前不需要获取所有源元素,只要获取到的源元素足够计算时,便生成结果元素. 流式处理的标准查询运算符返回值 ...

  9. C#3.0新增功能09 LINQ 标准查询运算符 02 查询表达式语法

    连载目录    [已更新最新开发文章,点击查看详细] 某些使用更频繁的标准查询运算符具有专用的 C# 语言关键字语法,使用这些语法可以在查询表达式中调用这些运算符. 查询表达式是比基于方法的等效项更具 ...

随机推荐

  1. solr基于jetty容器配置后台登陆角色用户名密码

    solr版本4.0.0 我的solr下载后解压在d盘,你的随意. 在D:\apache-solr-4.0.0\apache-solr-4.0.0\example\etc目录下新建role.proper ...

  2. GL_GL系列 - 预算管理分析(案例)

    2014-07-09 Created By BaoXinjian

  3. RabbitMQ介绍4 - 编程(C#客户端示例)

    C#终端的说明文档: http://www.rabbitmq.com/dotnet-api-guide.html 这里介绍使用RabbitMQ的几种典型场景. 1. 简单direct模式( http: ...

  4. sql中实现split()功能

    http://www.cnblogs.com/yangyy753/archive/2011/11/23/2260618.html 数据库中,总是遇到一些字段内容,想根据某个标识截取一下字符串,可是都想 ...

  5. redis info命令详解

    以一种易于解释(parse)且易于阅读的格式,返回关于 Redis 服务器的各种信息和统计数值. 通过给定可选的参数 section ,可以让命令只返回某一部分的信息: server : 一般 Red ...

  6. 无状态服务(stateless service)

    一.定义 无状态服务(stateless service)对单次请求的处理,不依赖其他请求,也就是说,处理一次请求所需的全部信息,要么都包含在这个请求里,要么可以从外部获取到(比如说数据库),服务器本 ...

  7. 拥抱 Android Studio 之五:Gradle 插件开发

    实践出真知 笔者有位朋友,每次新学一门语言,都会用来写一个贪吃蛇游戏,以此来检验自己学习的成果.笔者也有类似体会.所谓纸上得来终觉浅,绝知此事要躬行.这一章,笔者将以开发和发布一个 Gradle 插件 ...

  8. JAVA如何将PDF转换SWF格式的FLASH

    1. 需要用到的工具 SWFTools 下载地址 http://www.swftools.org/download.html,下载完成以后,直接安装就行  2.下面就是重点喽,详见Java代码解析 附 ...

  9. *(volatile unsigned long *) 语法

    #define GPJ2CON (*(volatile unsigned long *) 0xE0200280) 开始对于上面的语法不太理解,但通过拆分,我们可以看的更明白: 1.(unsigned ...

  10. C++学习3

    C++仍然在使用C语言的 char.int.long 等基本数据类型,它们在现代操作系统(Windows XP.Win7.Win10 等)中的长度如下表所示: longlong是C99新增的一种数据类 ...