一: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. awk查看接口耗时情况

    +1:LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Ag ...

  2. mac 开启 chrome 和 微信开发者工具 跨域

    微信开发者工具:open -n /Applications/wechatwebdevtools.app --args --disable-web-security --user-data-dir=/U ...

  3. C# 一维码生成

    概念 一维条码即指条码条和空的排列规则,常用的一维码的码制包括:EAN码.39码.交叉25码.UPC码.128码.93码,ISBN码,及Codabar(库德巴码)等. 条形码起源于 20 世纪 40 ...

  4. Python 多进程使用

    进程通信 方式一.共享内存(进程安全,效率高) 共享变量:multiprocessing.Value 共享数组:multiprocessing.Array   方式二.Manager对象:list, ...

  5. 表单元素(控件)不可见,你用visibility还是display?(转)

    属性大比拼:visibility和display的介绍 今天在做一个表单时涉及到这方面,当选中相应的选项后设置相应的几个元素(控件可见或不可见),后来还是用了visibility来实现.我们先来看下v ...

  6. VS编译静态库 .lib 其中Release 版本比Debug版本要大好多原因

    如果工程代码使用了: 把此选项关闭即可减少库大小不少:

  7. requesth获取参数

    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) t ...

  8. Elasticsearch-PHP 索引操作2

    索引操作 索引在客户端非常容易.因为关联数组很容易转换为JSON文档,索引文档只是提供正确和结构性的关联数组和调用方法. 单文档索引 当你索引你个文档时,可以自己提供一个ID,也可以让elastics ...

  9. oracle 创建一个用户,只能访问指定的对象

    1>创建一个ORACLE 的用户 create user username identified by pws; 2>给用户授权  grant connect,resource to us ...

  10. [SoapUI] 比较两个不同环境下的XML Response, 从外部文件读取允许的偏差值,输出结果到Excel

    import static java.lang.Math.* import java.text.NumberFormat import java.awt.Color import com.eviwar ...