一、Linq有两种语法:

1、  方法语法

2、  查询语法

下面举个例子看看这两种方法的区别

比如现在有一个学生类

public class student

{

public string username { get; set; }

public int age { get; set; }

public string sex { get; set; }

}

我们通过一个方法来添加很多同学

public IList<student> GetStu(int n)

{

IList<student> stuList = new List<student>();

for (int i = 0; i < n; i++)

{

student stu = new student();

stu.age = 25 + i;

stu.sex = "男" + i;

stu.username = "张三" + i;

stuList.Add(stu);

}

return stuList;

}

那么这个方法返回的就是一个list集合,下面我们就可以通过linq对这个集合进行操作

首先我们来查询所有的学生

A、查询语法:

var list = GetStu(10);

var result = from s in list

select new { stuname=s.username,sex=s.sex,age=s.age};

这是linq常用的语法from 变量 in 集合

Select 变量

B、方法语法

var result1 = list.Select(s1 => new { username = s1.username, age = s1.age, sex = s1.sex });

这就是方法语法,符合一般的C#语法

这两种方法的执行结果是一样的,唯一的区别就是语法

二、输出的方式

输出的方式也有两种,我们知道linq主要对集合进行操作的,所以一般都需要循环输出

第一种输出方式:

string stt = null;

foreach (var sa in result3)

{

stt += sa.username;

}

Response.Write(stt);

这是我们经常用到的foreach循环

第二种输出方式:

result.ToList().ForEach(s => { Response.Write(s.stuname+s.sex+s.age); });

这种方式很简介,直接调用ForEach方法,方法体内是一个limba表达式

另外说明下ToList()方法作用,在linq中有种延迟执行,就是当我们在from…select时候,返回的结果并没有执行,当我们循环调用的时候才执行,这就是延迟执行,有时候为了立即执行,我们需要用到ToList()

三、下面就来简单说说linq常用的几种查询

1、条件选择查询(where)

比如我们要查询年龄大于26的学生,可以这样写

var result = from s in list

where s.age>26     //条件查询

select s.username;

或者这样写

var result2 = list.Where(s => s.age > 25);   //条件查询

2、   查询排序

比如我们要按照学生年龄倒序排列查询

var result = from s in list

orderby s.age descending    //排序

where s.age>26     //条件查询

select s.username;

或者这样写

var result3 = list.OrderByDescending(s1 =>s1.age);

3、   数据查询分页显示

使用了Skip和Take方法

Skip作用跳过指定数量的元素

Take的作用是返回指定位置连续数量的元素

var list1 = GetList(50);

for (int i = 0; i < 5; i++)

{

Response.Write("这是第" + (i + 1) + "页");

var result = from s in list.Skip(i * 10).Take(10)

select s;

result.ToList().ForEach(s => { Response.Write(s); });

}

这就是分5页,每页显示10个的分页方式

4|、返回单个元素

用到First(),FirstOrDefault(),single,singleOrDefault()

First():返回第一个元素,如果没有,则抛出异常

FirstOrDefault():返回第一个元素,如果没有,则返回空,一般情况下会返回null

Single:返回的是元素中唯一的元素,如果小于一条,则抛出异常

singleOrDefault:返回的是元素中唯一的元素,如果小于一条,则返回空,通常是null

var result1 = from r in list1

select r;

var rt = result1.First();

result1.Single()

上面只是简单的介绍了下linq的用法,具体项目中用到了,在具体对待

下载:/Files/shuang121/linq的基本操作.doc

linq to sql操作

linq基本操作的更多相关文章

  1. 一篇文章教你学会ASP.Net Core LINQ基本操作

    一篇文章教你学会ASP.Net Core LINQ基本操作 为什么要使用LINQ LINQ中提供了很多集合的扩展方法,配合lambda能简化数据处理. 例如我们想要找出一个IEnumerable< ...

  2. C# LINQ 基本操作实例

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  3. Linq 基本操作

    在linq中排序方法有: OrderBy()  --对某列升序排序 ThenBy()    --某列升序后对另一列后续升序排序 OrderByDescending() --对某列降序排序 ThenBy ...

  4. .NETCoreCSharp 中级篇2-3 Linq简介

    .NETCoreCSharp 中级篇2-3 本节内容为Linq及其拓展方法.Linq中表达式树的使用 简介 语言集成查询(LINQ)是一系列直接将查询功能集成到C#语言的技术统称.数据查询历来都表示为 ...

  5. Linq查询基本操作

    摘要:本文介绍Linq查询基本操作(查询关键字) - from 子句 - where 子句 - select子句 - group 子句 - into 子句 - orderby 子句 - join 子句 ...

  6. C#中Linq查询基本操作

    摘要:本文介绍Linq查询基本操作(查询关键字) - from 子句 - where 子句 - select子句 - group 子句 - into 子句 - orderby 子句 - join 子句 ...

  7. Linq学习笔记四之linq to sql 的基本操作

    首先需要在项目中新增一个 linq  to sql 的服务 新增项,数据,LINQ TO sql 类的这个方法 第二步需要一个model类,用作映射 [Table] public class S_ZD ...

  8. linq to xml 基本操作

    使用XDocument类来进行简单的xml操作,用于软件参数的设置保存. using System; using System.Collections.Generic; using System.Li ...

  9. Linq 查询基本操作

    - from 子句 - where 子句 - select子句 - group 子句 - into 子句 - orderby 子句 - join 子句 - let 子句 - 复合from子句 - 在某 ...

随机推荐

  1. Groovy 设计模式 -- 借贷

    借贷模式 http://groovy-lang.org/design-patterns.html#_loan_my_resource_pattern The Loan my Resource patt ...

  2. luogu 2014 选课 树上背包

    树上背包 #include<bits/stdc++.h> using namespace std; ; const int inf=0x3f3f3f3f; vector<int> ...

  3. Docker 操作记录

    Docker docker info 查看信息 docker 更改镜像目录 方式:1.配置文件修改 # cat /etc/sysconfig/docker |grep -v ^# |grep -v ^ ...

  4. [C++]PAT乙级1007.素数对猜想 (20/20)

    /* 1007. 素数对猜想 (20) 让我们定义 dn 为:dn = pn+1 - pn,其中 pi 是第i个素数.显然有 d1=1 且对于n>1有 dn 是偶数.“素数对猜想”认为“存在无穷 ...

  5. WordPress分类列表函数:wp_list_categories用法及参数详解举例

    http://www.511yj.com/wordpress-wp-categories.html 注意: 1. wp_list_categories() 和 list_cats() 以及 wp_li ...

  6. dwr出现session error

    把项目冲tomcat6迁移到tomcat7之后,在项目运行中发现用到dwr的地方出现了session error错误, 网上搜了一下,是因为tomcat7的安全机制. 解决方法: 在项目的web.xm ...

  7. 事件对象event

    每个事件都有默认事件event对象 e.target 事件目标对象 e.keycode 键码 e.stopPropogation();//阻止默认事件

  8. javascript常用函数封装——运动、cookie、ajax、获取行内样式兼容写法、拖拽

    运动.cookie.ajax.获取行内样式兼容写法.拖拽封装大合集. //url,data,type,timeout,success,error function ajax(options){ //- ...

  9. Java开发环境配置(5)--Web 服务器--Tomcat--安装过程遇到的问题

    1.参考例子:--- 怎样安装配置tomcat 8_百度经验https://jingyan.baidu.com/article/ff42efa91132a0c19e220208.html 安装与配置T ...

  10. python初级实战-----主机在线情况监控web

    背景 公司有600多台服务器,打算写一个小程序,能一眼看见哪些服务器不在线. 大体思路是: 1.把所有服务器ip存进数据库,ping命令判断服务器是否在线 2.更新数据库中ip的状态 3.简单的web ...