MVC ---- 标准查询运算符
标准查询运算符:定义在System.Linq.Enumerable类中的50多个为IEnumerable<T>准备的扩展方法,这些方法用来
对它操作的集合进行查询筛选。
筛选集合Where:需要提供一个带bool返回值的“筛选器”,从而表明集合中某个元素是否应该被返回。
查询投射,返回新对象集合IEnumerable<TSource> Select()
统计数量 int Count()
多条件排序 Order By().ThenBy().ThenBy()
集合链接Join()
......
public class NineDemo
{
public static void TestNine()
{
List<User> usList =Five.GetUserList();
List<Dept> dtLsit =Five.GetDeptList(); //1.Where的用法
List<User> user = usList.Where(new Func<User,bool>(delegate(User u){return u.Age >})).ToList(); //遍历所以用户姓名+年龄
usList.ForEach(u=>Console.WriteLine(u.Name+u.Age); //遍历 年龄大于12的用户
user.ForEach(u=>Console.WriteLine(u.Name); //缩写 年龄大于12的用户
List<User> user = usList.where(u=>u.Age > ); // 2. Order排序
List<User> user = usList.OrderByDescending(u=>u.Age).ToList();
//先按年龄降序、手机号降序、姓名升序
List<User> user = usList.OrderByDescending(u=>u.Age).ThenByDescending(u=>u.Phone).ThenBy(u=>u.Name).ToList(); // 3. Join 链接
//User 和 Dept(deptId) 要有关系,User中有deptId .
//得到一个新的集合(匿名类) (u代表usList,p代表dtList)
var ud = usList.Join(dtLsit,u=>u.DeptId,p=>DeptId,(u,p)=>new {UserName=u.Name,LoginName=u.LoginName,Deptname=p.DeptName}).ToList(); //遍历
ud.ForEach(u=>Console.WriteLine(u.Name+u.DeptName));
-------------
//第二种方式
//临时封装一个实体,用来接收新的数据
[Serializable]
public class UserDept{
public string UserName{get;set;}
public string LoginName{get;set;}
public string Deptname{get;set;}
} //得到一个新的集合(UserDept集合接收)
List<UserDept> ud = usList.Join(dtLsit,u=>u.DeptId,p=>DeptId,(u,p)=>new UserDept(){UserName=u.Name,LoginName=u.LoginName,Deptname=p.DeptName}).ToList(); //遍历
ud.ForEach(u=>Console.WriteLine(u.Name+u.DeptName)); //4. GroupBy 分组
//按照集合中的用户的部门编号进行分组(用IEnumerable<IGrouping<string,User>>接收)
IEnumerable<IGrouping<string,User>> usersGroup = usList.GroupBy(u=>u.DeptId);
//也可以放在匿名中
var usersGroup = usList.GroupBy(u=>u.DeptId);
//遍历
foreach(IGrouping<string,User> group in userGroup){
Console.WriteLine("部门编号"+group.Key);
//遍历组中的元素
foreach(User _user in group){
Console.WriteLine(_user.Name+_user.Phone);
}
} //5. Skip+Take分页
//Skip的意思:跳过,Take:拿,取
//前提数据源按一定的列进行排序
List<User> pageList = usList.OrderBy(u=>u.Name).ToList();
//取第二页数据
List<User> us = GetPageListByIndex(pageList,);
//遍历
us.ForEach(u=>u.Name+u.Phone); //封装一个方法
//根据页码提取当页数据 ,list要分页的数据,pageIndex页码
static List<User> GetPageListByIndex(List<User> list,int pageIndex){
int pageSize = ;
return list.Skip((pageIndex-)*pageSize).Take(pageSize).ToList();
} }
}
MVC ---- 标准查询运算符的更多相关文章
- .NET中那些所谓的新语法之四:标准查询运算符与LINQ
开篇:在上一篇中,我们了解了预定义委托与Lambda表达式等所谓的新语法,这一篇我们继续征程,看看标准查询运算符和LINQ.标准查询运算符是定义在System.Linq.Enumerable类中的50 ...
- .NET LINQ标准查询运算符
标准查询运算符概述 “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法. 大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了 IEnumerable<T> ...
- SQO (标准查询运算符)方法 & Linq To Object
#region SQO (标准查询运算符) 方法 #region Where() Find() FindAll() FirstOrDefault()等方法 static void c01where() ...
- 十四、C# 支持标准查询运算符的集合接口
支持标准查询运算符的集合接口. System.Linq.Enumeralbe类提供的一些常用的API 来执行集合处理 1.匿名类型 2.隐匿类型的局部变量 3.集合初始化器 4.集合 5.标准查询运算 ...
- “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法
“标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法.大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了IEnumerable<T> 接口或 IQueryable& ...
- C#3.0新增功能09 LINQ 标准查询运算符 01 概述
连载目录 [已更新最新开发文章,点击查看详细] 标准查询运算符 是组成 LINQ 模式的方法. 这些方法中的大多数都作用于序列:其中序列指其类型实现 IEnumerable<T> 接 ...
- C#3.0新增功能09 LINQ 标准查询运算符 02 查询表达式语法
连载目录 [已更新最新开发文章,点击查看详细] 某些使用更频繁的标准查询运算符具有专用的 C# 语言关键字语法,使用这些语法可以在查询表达式中调用这些运算符. 查询表达式是比基于方法的等效项更具 ...
- C#3.0新增功能09 LINQ 标准查询运算符 03 按执行方式的分类
连载目录 [已更新最新开发文章,点击查看详细] 标准查询运算符方法的 LINQ to Objects 实现主要通过两种方法之一执行:立即执行和延迟执行.使用延迟执行的查询运算符可以进一步分为两种 ...
- C#3.0新增功能09 LINQ 标准查询运算符 04 运算
连载目录 [已更新最新开发文章,点击查看详细] 本篇主要介绍标准查询运算符的常用运算功能. 01 对数据排序 排序操作基于一个或多个属性对序列的元素进行排序. 第一个排序条件对元素执行主要排序. ...
随机推荐
- 下载google play上最新版的apk
注意,是下载最新版的方法,不是像很多网站下的是旧版本 http://techapple.net/2014/09/3-websites-directly-download-apk-google-play ...
- [LeetCode] 237. Delete Node in a Linked List_Easy tag: Linked List
Write a function to delete a node (except the tail) in a singly linked list, given only access to th ...
- Oracle存储过程中游标的简单使用
存储过程中查询语句如何返回多行结果? 我们知道,如果存储过程中查询语句有多行结果输出,会报错:ORA-01422: exact fetch returns more than requested nu ...
- Summary: Java Inheritance
In this tutorial we will discuss about the inheritance in Java. The most fundamental element of Java ...
- 2:1 Strus2架构
一: 二: 表示:当以/login或者login.do表示的请求过来,就使用class指定的LoginAction类来处理,处理完了返回一个结果字符串,若果结果字符串是"fail" ...
- UVM中的driver组件
一般UVM环境中的Driver组件,派生自uvm_driver. uvm_dirver派生自uvm_component. class uvm_driver #(type REQ = uvm_sequ ...
- HTTP 协议入门
本文转载自:http://www.ruanyifeng.com/blog/2016/08/http.html HTTP 协议是互联网的基础协议,也是网页开发的必备知识,最新版本 HTTP/2 更是让它 ...
- python-正则表达式练习题
1.匹配一行文字中的所有开头的字母内容 #coding=utf-8 import re s="i love you not because of who you are, but becau ...
- centos7 centos-home 磁盘转移至centos-root下
1.查看分区 df -h (centos-home和centos-root每人的名字可能不一样) vgdisplay (查看空闲磁盘大小) 2.备份home分区文件 tar cvf /tmp/home ...
- linux基础命令---chattr
chattr 改变文件的属性,这个命令只有超级用户才能使用.这个指令适用于ext2.ext3.ext4.xfs.ubifs.reiserfs.jfs系统. 此命令的适用范围:RedHat.RHEL.U ...