c#中的linq二

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace LinqInfo
{
public class Stu
{
public int ID { set; get; } public string Name { get; set; } public string Tel { get; set; } public string Address { get; set; }
} public class GradeInfo
{
public int StuID {get;set; }
public string Course{get;set;}
public int grade{get;set;} }
class Program
{
static void Main(string[] args)
{
List<Stu> list = new List<Stu>()
{
new Stu{ID=,Name="jack1",Tel="",Address="ChengDu"},
new Stu{ID=,Name="jack2",Tel="",Address="ChengDu"},
new Stu{ID=,Name="jack3",Tel="",Address="ChengDu"},
new Stu{ID=,Name="jack4",Tel="",Address="ChengDu"},
new Stu{ID=,Name="jack5",Tel="",Address="ChengDu"} }; //where 关键字
var query =
from li in list
where li.Name == "jack1"
select li;
//order by关键字的
//ascending 升序
//descending 降序
var query1 =
from s in list
orderby s.ID ascending
select s;
//group by的使用
var query2 =
from s in list
group s by s.Address into g
select g;
//group by 求最大值
var max =
from s in list
group s by s.Address into g
select new {
g.Key, //分组字段
MaxId=g.Max(p=>p.ID) //最大的ID
}; //group by 求最小值
var min =
from s in list
group s by s.Address into g
select new {
g.Key,
MidId=g.Min(p=>p.ID)
}; //group by 平均值
var avg =
from s in list
group s by s.Address into g
select new
{
g.Key,
avgInfo = g.Average(p => p.ID)
};
//group by 求和
var sum =
from s in list
group s by s.Address into g
select new
{
g.Key,
Sum=g.Sum(p=>p.ID)
};
//这些就是group by 的基本使用滴呀; //接下来就是各种连接滴呀;
List<GradeInfo> gradeList = new List<GradeInfo>()
{
new GradeInfo(){StuID=,Course="语文",grade=},
new GradeInfo(){StuID=,Course="英语",grade=},
new GradeInfo(){StuID=,Course="数学",grade=},
new GradeInfo(){StuID=,Course="语文",grade=},
new GradeInfo(){StuID=,Course="英语",grade=},
new GradeInfo(){StuID=,Course="数学",grade=},
//模拟错误数据
new GradeInfo(){StuID=,Course="wrong",grade=}
}; //然后再来我们的各种连接查询滴呀;
var innerJoin =
from s in list
join g in gradeList
on s.ID equals g.StuID
select new
{
Name=s.Name,
Grade=g.grade
}; //左连接;
var leftJoin =
from s in list
join g in gradeList
on s.ID equals g.StuID into joinData
from g in joinData.DefaultIfEmpty()
select new
{
Name=s.Name,
Grade= g!=null ? g.grade: //返回相同的数据类型;
}; //整体来说,再数据赛选上的效果是挺不错滴呀; //右连接; 其实左连接 和右 连接是一个相对的概念;
var rightJoin =
from g in gradeList
join s in list
on g.StuID equals s.ID into joinData
from s in joinData.DefaultIfEmpty()
select new
{
Grade=g.grade,
Name=s!=null?s.Name:""
}; var result = rightJoin;
//最后在附带一中linq分页的方法;
var val = (from u in list
orderby u.ID ascending
select u).Skip().Take();
//每页两条,第二页
/*
*
* var q=query.take(n) 这样只能取出前条n记录,
* 但是还是让我们看到了分页的曙光,还是还有个skip吗,
* skip可以取出除去满足条件的剩下的记录。
* 如果我们要把数据以每页pagesize的数量来进行分页,
* 很简单,很skip(pagersize*pagenum)然后在剩下的记录中take(pagesize)不就得到了想要的数据了么。
*
* */
var xx = val; Console.WriteLine("over");
Console.ReadLine();
} }
}

c#中的linq二的更多相关文章

  1. C#中的Linq to Xml详解

    这篇文章主要介绍了C#中的Linq to Xml详解,本文给出转换步骤以及大量实例,讲解了生成xml.查询并修改xml.监听xml事件.处理xml流等内容,需要的朋友可以参考下 一.生成Xml 为了能 ...

  2. C#中的线程二(Cotrol.BeginInvoke和Control.Invoke)

    C#中的线程二(Cotrol.BeginInvoke和Control.Invoke) 原文地址:http://www.cnblogs.com/whssunboy/archive/2007/06/07/ ...

  3. C语言中如何将二维数组作为函数的参数传递

    今天写程序的时候要用到二维数组作参数传给一个函数,我发现将二维数组作参数进行传递还不是想象得那么简单里,但是最后我也解决了遇到的问题,所以这篇文章主要介绍如何处理二维数组当作参数传递的情况,希望大家不 ...

  4. IT公司100题-35- 求一个矩阵中最大的二维矩阵(元素和最大)

    问题描述: 求一个矩阵中最大的二维矩阵(元素和最大).如: 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 中最大的是: 4 5 9 10   分析: 2*2子数组的最大和.遍历求和,时 ...

  5. C++中的异常处理(二)

    C++中的异常处理(二) 标签: c++C++异常处理 2012-11-24 20:56 1713人阅读 评论(2) 收藏 举报  分类: C++编程语言(24)  版权声明:本文为博主原创文章,未经 ...

  6. c#中的linq一

    c#中的linq 测试数据: using System; using System.Collections.Generic; using System.Linq; using System.Text; ...

  7. Expert C# 5.0中的Linq部分

    1.先看看.NET中的Linq 2.扩展方法 3.Lambda表达式和表达式树 4.Linq中的延迟操作 5.Linq中的查询方法 5.1分割操作 5.2连接操作 5.3排序操作 5.4分组和连接 5 ...

  8. 在VB中使用Linq To SQLite注意事项

    昨天使Linq To SQLite 支持VB,今天在VB中写了几条Linq语句,发现了几个问题: 1.在Linq To SQLite中的Linq语句查询后并不是得到的匿名数据类,而是将Linq转换为S ...

  9. VB.NET中使用Linq TO SQL添加数据后获得自增长列ID

    VB.NET中使用Linq TO SQL添加数据后获得自增长列ID: Dim tempOrdre As New Order With { .CustomerID = cmbCustomerName.S ...

随机推荐

  1. HDU 4630 No Pain No Game(树状数组)

    题目链接 看的别人的题解,离线之后,按r排序,枚举1-n,利用pre[j],存上次j的倍数出现的位置,树状数组里统计的当前位置到最后的最大值,树状数组是求区间最值其实应该很麻烦的,但是此题用法只是求到 ...

  2. QT基本使用

    安装方法: ubuntu12.04下安装QT方法:http://blog.csdn.net/xsl1990/article/details/8299756 输入以下命令: sudo apt-get i ...

  3. hdu I NEED A OFFER!

    这道题是道很基本的0/1背包的问题,为了使解题很简单一点,可以将题目中要求的最大概率转换成不能录取的最小概率,这样1-dp[n]即为至少有一个offer的最大概率.状态方程 为:dp[j]=min{d ...

  4. FTP协议详解(转)

    FTP 是File Transfer Protocol(文件传输协议)的英文简称,而中文简称为“文传协议”.用于Internet上的控制文件的双向传输.同时,它也是一个应用程序(Application ...

  5. 使用java代码,动态给TextView设置drawable

    Drawable country = context.getResources().getDrawable(drawableId); country.setBounds(0, 0, country.g ...

  6. 字符数组char

     数组做sizeof的参数不退化,传递给strlen就退化为指针: #include<stdio.h> #include<stdlib.h> #include<strin ...

  7. bug 发表文章不显示图片

    bug 描述: 现象是我们这不能发布图片, 测试说患教方向是可以正常发布图片的(还是要感激测试,正是他们鞭策我们不断挑战困难,解决之,从而提高自己姿势水平). 图片没上传上去, 服务端协助查找发现没调 ...

  8. 泌尿系统 Excretory system

    https://zh.wikipedia.org/wiki/泌尿系统 泌尿系統,有時也歸類於排泄系統(Excretory system)的一部分,負責尿液的產生.運送.儲存與排泄.人類的泌尿系統包括左 ...

  9. 7添加一个“X”到HTML:转到XHTML

    XHTML中的X代表extensible,是以XML为基础的另一种说法.XML表示可扩展的标记语言. XML是一种可以用来开发新的标记语言的语言,而HTML只是一门标记语言. HTML转化为XHTML ...

  10. BadgeView的使用介绍

    在现在大部分的信息发布类应用,都有这样的一个功能:当后台数据更新,比如有系统消息或者是用户间有互动的时候,通过在控件上显示一个小红点来提示用户有新的信息.一般来说,这种业务需求,我们可以在布局文件中隐 ...