一:C#的一个分支Linq

二:学Linq需要有一些基础知识

1. var 隐式类型

2. 匿名类型/匿名方法

3. 自动属性

4. 委托/泛型的委托

5. lambda

6. 扩展方法

7. 对象初始化器  (匿名对象)

8. IEnumerable/yield/GetEnumerator

三:linq的作用的是什么 【大一统】

什么叫大一统: 就比如 linq中包含了对象查询,数据查询,xml查询等, 都包含在一起。

1. linq 【对象查询,数据查询,xml查询, xxx】

2. linq 其实就是使用扩展方法的lambda表达式。

四:linq to object

1. 原来 VS 现在

《1》 定义一个类

《2》 初始化了一个List集合。

《3》 foreach循环遍历。

namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
//找到str中包含“A”的字符串,然后已大写字符串和字符串长度的形式转存出来。
//{Word="AS",Length=2},{Word="SPA",Length=3}
//最原始的方式
var strs = new string[] { "is", "as", "spa" };
List<Word> words = new List<Word>();
foreach (var str in strs)
{
var upper = str.ToUpper();
if (upper.Contains("A"))
{
words.Add(new Word() { Str = upper, Length = upper.Length });
}
}
//现在的读取方式
var query = from str in strs
let upper = str.ToUpper() //定义临时变量
where upper.Contains("A")
select new { Str=upper, Length=upper.Length };
}
}
class Word
{
public string Str { get; set; }
public int Length { get; set; }
}
}

2. linq to sql/ ado.net entityframework

这两个都是用linq的方式读取/操作数据库。

原来: 我们是写sql代码的形式操作数据库。

表达式树,将lamada用树的形式存储起来,这样就方便将lambda表达式
解析成sql。

3. linq to dataset => datatable

原来:我们操作dataset/datatable 有foeach的形式。

现在:我们就可以用linq的方式了。

4. linq to xml

原来:用xmlwriter和xmlreader的形式来操作xml。

现在:我们用linq中的XDocument和XElement这样两种方式操作xml。

当然,大家一定要知道 linq to xml 其实是对xmlwriter的一种高层封装。

5. linq to xxx

这里的xxx需要自己去实现IQueryable接口。

Linq的使用场景简介和认识的更多相关文章

  1. 第15.47节、PyQt显示部件:QGraphicsView图形视图和QGraphicsScene图形场景简介及应用案例

    专栏:Python基础教程目录 专栏:使用PyQt开发图形界面Python应用 专栏:PyQt入门学习 老猿Python博文目录 老猿学5G博文目录 一.概述 Designer中的Graphics V ...

  2. Linqpad使用(调试Linq、结合linq调试业务场景、表格内编辑数据)

      linqpad是一款linq语句调试工具,功能如下: 1.直接执行linq语句并查看生成的原生sql语句 2.可结合linq+C#代码进行业务场景调试 3.表格内直接新增.修改.删除数据 4.直接 ...

  3. 转载LINQ系列OrderBy(), ThenBy()简介

    前言 前面两篇分别介绍了 Where() 与 Select() ,这篇则是要介绍 OrderBy() 与 ThenBy() ,这几个东西看起来最像 SQL 上会用到的语法,但切记一点,这边介绍的是 L ...

  4. 转 redis使用场景 简介

    Redis实战(五) 聊聊Redis使用场景 发表于 2016-11-21 | 数据存储 | Redis 文章目录 1. 使用场景说明 1.1. 计数器 1.2. 排行榜 1.3. 用于存储时间戳 1 ...

  5. Linq To Excel使用简介二

    目录: 1.常用方法介绍 2.查询符合条件的数据 3.手动添加映射 4.其他用法   1.常用方法介绍         里面有一些常见的方法,如下: Worksheet 获得工作表中的数据 Works ...

  6. 第四十章、PyQt显示部件:QGraphicsView图形视图和QGraphicsScene图形场景简介及应用案例

    专栏:Python基础教程目录 专栏:使用PyQt开发图形界面Python应用 专栏:PyQt入门学习 老猿Python博文目录 老猿学5G博文目录 一.概述 Designer中的Graphics V ...

  7. Key/Value之王Memcached初探:三、Memcached解决Session的分布式存储场景的应用

    一.高可用的Session服务器场景简介 1.1 应用服务器的无状态特性 应用层服务器(这里一般指Web服务器)处理网站应用的业务逻辑,应用的一个最显著的特点是:应用的无状态性. PS:提到无状态特性 ...

  8. NoSQL初探之人人都爱Redis:(3)使用Redis作为消息队列服务场景应用案例

    一.消息队列场景简介 “消息”是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含文本字符串:也可以更复杂,可能包含嵌入对象.消息被发送到队列中,“消息队列”是在消息的传输过程中保存消息的容器 ...

  9. Redis作为消息队列服务场景应用案例

    NoSQL初探之人人都爱Redis:(3)使用Redis作为消息队列服务场景应用案例   一.消息队列场景简介 “消息”是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含文本字符串:也可以更 ...

随机推荐

  1. Python基础部分

    Python基础一 Python基础二 字符串相关操作一 列表及元组 字典介绍及其操作 Python 中的 is 和 == 编码和解码 Python中的 set 与 深浅拷贝 Python 的文件操作

  2. sql之分区域分段统计

    sql之分区域分段统计 需求:在一个表中,有两列分别标记行政区划代码和家庭成员人数,需要得到不同乡镇的家庭成员人数在1-2人,3-4人,5-6人,6人以上的家庭数的表格 思路: 用case when对 ...

  3. delphi XE8 Android SDK SET

    delphi XE Berlin Android SDK SET RAD>Tools>Options>SDk Manager> https://dl-ssl.google.co ...

  4. directshow 虚拟摄像头 实例 代码解读

    directshow 虚拟摄像头 实例 代码解读 本文只介绍这个源码的大致构成以及怎么修改,因为其他的我也不会啊哈哈哈,我就是用QQ调用虚拟摄像头读取我自己的视频或者图片播放给别人让别人以为这就是实时 ...

  5. sudo:must be setuid root 解决方法 <转>

    http://walkerqt.blog.51cto.com/1310630/1354103

  6. tnsping命令解析

    tnsping命令格式: tnsping <service_name> n n的意义是可以让tnsping ping多次 例: c:\Documents and Settings\Tony ...

  7. pl/sql中if语句的使用

  8. 解剖Nginx·模块开发篇(1)跑起你的 Hello World 模块!

    1 学习 Nginx 模块开发需要有哪些准备? 需要的预备知识不多,有如下几点: 有过一些 C 语言的编程经历: 知道 Nginx 是干嘛的,并有过编写或改写 Nginx 的配置文件的经历. OK,就 ...

  9. centos6.5 源码安装 mysql

    1.下载源码包 我的版本:mysql-5.6.4-m7.tar.gz 2.安装之前先卸载CentOS自带的MySQL [root@localhost ~]# yum remove mysql 3.编译 ...

  10. java实现文件的拷贝以及文件的删除

    /** * 将文件拷贝到指定目录 * @param oldAddress 文件所在目录(文件的全路径) * @param newAddress 指定目录(包含复制文件的全名称) * @throws E ...