11、Linq的使用
一、种类
1.Linq to Objects,实现了IEnumerable<T>集合对象的集成查询
2.Linq to sql,针对关系数据库MSSQL的解释查询
3.Linq to Entities,通过实体数据模型,支持多个数据库的Linq
4.Linq to XML,针对XML文档的集成查询
二、λ表达式
1、形式
(1)一个参数+一条语句/c#表达式:参数 = > C# 表达式
(2)一个参数+一条或多条语句:参数 = > { 处理语句 }
(3)多个参数:(参数1,参数2,……参数n) => { 处理语句 }
(4)无参数:() = > { 处理语句 }
可以将表达式赋给委托对象:
delegate int myDelegate(int i );
myDelegate dobj = s => { return s * s; };
//或返回值就是表达式结果
myDelegate dobj1 = s => s * s;
具体使用参考:18、(番外)匿名方法+lambda表达式
2、查询语法:
1)在list集合中的使用:
如果是用匿名方法来查询某条信息:
List<string> names = new List<string>() { "李", "王" };
List<string> lnames = names.FindAll(delegate(string s) { return s[] == '李'; });//查询第一个字是李的集合
改为lambda表达式来查询,就可以省略return和委托字段:
List<string> lnames1 = names.FindAll(s => s[] == '李');
调用方法:集合.Where().Orderby.Select()……
a.where 只接受一个输入序列和一个谓词作为参数,返回一个结果续集
b.orderby(n=>n) 调用自身,orderby(n=>n.Length)调用长度……可以按长度或按字母顺序对数组进行排序
c.select 投影
3、查询表达式:以from开头,以select或group结束。
1)基本形式:
var 结果集= from 元素变量 in 数据源 select 元素或元素属性
2)有where子句的形式:
var 结果集= from 元素变量 in 数据源 where 布尔表达式 select 元素或元素属性
例:
var bi = from b in names where b.GetType() == typeof(string) select b;
3)into:在 select 或 group 子句后,用“into 变量名”开始新的查询(相当于把一个查询结果放入表里在对表进行操作)
let:直接引入一个新变量,在select 子句前 (let 变量名= ……)
三、Linq to Objects
1、投影输出多个标量元素
select new ProjectionItem{ Name = s.name,Age = s.age }
//表示投影s对象的两个字段,创建ProjectionItem的对象(可匿名),s.name和s.age为字段值,也可以自行拓展字符串
2、运算符等(略)
四、Linq to sql
1、需要先创建 DataContext 对象连接数据库:
var content = new DataContext(connection);
2、调用 GetTable 来获得查询对象
Table<Student> students = content.GetTable<students>();
3、执行查询(略)
4、用 content.SubmitChanges() 把修改保存到数据库中
11、Linq的使用的更多相关文章
- LINQ体验(11)——LINQ to SQL语句之Null语义和String/DateTime方法
在本系列中.主要介绍LINQ to SQL基础的东西,由于LINQ太强大了,它对我们寻常使用不同的数据源有着不同的内容,其包含对于SQL Server 数据库的LINQ to SQL:对于XML 文档 ...
- 新语法11. – LINQ
LINQ分组: IEnumerable<IGrouping< group dog by dog.Age; 遍历分组: foreach (IGrouping<int, Dog> ...
- LINQ系列目录
1. LINQ准备 1.1 C#中与LINQ相关特性 2. LINQ to Object 2.1 LINQ to Object投影操作符(Select/SelectMany/Let) 2.2 LINQ ...
- Linq 学习笔记
简介: LINQ 提供一种统一的方式,让我们能在C#语言中直接查询和操作各种数据. LINQ是用来描述数据访问总体方式的术语.LINQ to Object是针对实现了IEnumerable< ...
- Linq to Sql : 三种事务处理方式
原文:Linq to Sql : 三种事务处理方式 Linq to SQL支持三种事务处理模型:显式本地事务.显式可分发事务.隐式事务.(from MSDN: 事务 (LINQ to SQL)).M ...
- 当你使用LINQ做底层时,最好设计一个工厂,不要把LINQ的动作暴露给业务层
1: using System; 2: using System.Collections.Generic; 3: using System.Linq; 4: using System.Text; 5: ...
- C#基础知识简单梳理
本文是转发博友的总结,方便自己以后随时温习: 1.值类型和引用类型 1.1堆和栈 简单的说值类型存放在堆栈上面,引用类型的数据存放在托管堆上面(它的引用地址却存放在堆栈上面)! 栈:它是一个内存数组, ...
- 转载文章----C#基础概念
转载地址:http://www.cnblogs.com/zhouzhou-aspnet/articles/2591596.html 1.值类型和引用类型 1.1堆和栈 简单的说值类型存放在堆栈上面,引 ...
- 用c#操作Mongodb(附demo)
因为需要,写了一个基于泛型的helper,这样要使用起来方便一点. 为了大家也不重复造轮子,所以发出来希望能帮到谁. 复杂的查询最好用linq,这也是mongodb官方建议的. mongodb的C#配 ...
- C#常用特性
1.服务器控件ID .NET服务器控件有三个ID,即:ID,ClientID和UniqueID ID为服务器控件的服务器标示,在服务器代码中通过ID来唯一区分服务器控件: ClientID是服务器控件 ...
随机推荐
- 初始通过 FastClick.notNeeded 方法判断是否需要做后续相关处理
其实前面几篇文章大家都遇到一些错误,很多时候呢,我并没有直接回复解决方案,不是LZ不想告诉大家,如果不想那就不写这个了,估计博客园啊CSDN啊那么多写博客的,很少有人把现用框架分享出来,既然分享就毫不 ...
- [IOS 开发] 自定义(重写) UITableViewCell的高亮背景色
IOS的sdk中,对UITableViewCell的高亮背景色只支持两种颜色,分别为UITableViewCellSelectionStyleBlue和UITableViewCellSelection ...
- js 判断是什么类型浏览器
// firefoxif ( window.sidebar && "object" == typeof( window.sidebar ) && ...
- DNS bind子域授权安装
失败经验:rhel 6.x bind 9.8,两台做子域授权,最后失败.原因不详. 改用rhel 5.5, bind 9.3,同样的配置,就成功了.具体记录一下9.3的配置. 安装:采用安装RHEL时 ...
- docker index服务概述
index顾名思义“索引”,index服务主要提供镜像索引以及用户认证的功能.当下载一个镜像的时候,首先会去index服务上 做认证,然后查找镜像所在的registry的地址并放回给docker客户端 ...
- android异常: java.net.ConnectException: localhost/127.0.0.1:8080 - Connection refused
android手机做下载文件时,报了如下异常: java.net.ConnectException: localhost/127.0.0.1:8080 - Connection refused 模拟器 ...
- Spring(3)
一.Spring容器 Spring 提供了两种类型的IOC容器(后面还会讲到AOP容器): (1)BeanFactory:IOC容器的基本实现,是Spring框架的基础设施,面向Spring的本身 ( ...
- C#遍历XML文件动态加载菜单
通过遍历XML文件动态加载菜单,顺便利用WebBrowser控件实现一个简单的桌面浏览器 效果如下: 代码如下: XMLFile1.xml <?xml version="1.0&quo ...
- C++ 之 新式转型操作符
四种新式转型: const_cast.dynamic_cast.reinterpret_cast.static_cast!! 1.const_cast : 去除常量性 2.dynamic_cast ...
- clip:rect矩形剪裁
clip:rect(top right bottom left);依据上-右-下-左的顺序提供自图片左上角为(0,0)坐标计算的四个偏移数值,其中任一数值都可用auto替换. 矩形剪裁 还需要绝对定位 ...