前言

LINQ(Language Integrated Query)语言集成查询是一组用于c#和Visual Basic语言的扩展。它允许编写C#或者Visual Basic代码以查询数据库相同的方式操作内存数据。

叙述

What is LINQ?

LINQ(Language Integrated Query)是C#和VB.NET中的统一查询语法,用于保存和检索不同来源的数据。它集成在C#或VB中,从而消除了编程语言和数据库之间的不匹配,以及为不同类型的数据源提供单个查询接口。
  例如,SQL是一种结构化查询语言,用于保存和检索数据库中的数据。同样的,LINQ是一个用C#和VB.NET构建的结构化查询语法,用于保存和检索来自不同类型数据源的数据,如对象集合,SQL服务器数据库,XML,Web服务等。
   LINQ总是与对象一起工作,因此您可以使用相同的基本编码模式来查询和转换XML文档,SQL数据库,ADO.NET数据集,.NET集合以及LINQ提供程序可用的任何其他格式的数据。

Why LINQ?

(1)熟悉的语言:开发人员不必为每种类型的数据源或数据格式学习新的查询语言。
(2)较少的编码:与传统方法相比,它减少了要编写的代码量。
(3)可读代码: LINQ使代码更易读,所以其他开发人员可以轻松理解和维护代码。
(4)查询多个数据源的标准化方式:可以使用相同的LINQ语法来查询多个数据源。
(5)编译查询的时间安全性:在编译时提供对象的类型检查。
(6)智能感知支持: LINQ为通用集合提供智能感知。
(7)整形数据:您可以检索不同形状的数据。

LINQ查询语法

有两种基本的方法来编写一个LINQ查询IEnumerable集合或IQueryable数据源。
  1、查询语法或查询表达式语法
  2、方法语法或方法扩展语法或Fluent

LINQ查询语法

查询语法与数据库的SQL(结构化查询语言)类似。它是在C#或VB代码中定义的。

具体的语法:

(1)从<范围变量>在<IEnumerable <T>或IQueryable <T>集合>
(2)<标准查询运算符> <lambda表达式>
(3)<select或groupBy运算符> <结果形成>

LINQ查询语法从关键字开始,以select关键字结束。以下是LINQ查询示例,它返回包含单词“Tutorials”的字符串集合。

// string collection
IList<string> stringList = new List<string>() { "C# Tutorials","VB.NET Tutorials","Learn C++","MVC Tutorials" ,"Java"
};// LINQ Query Syntax
var result = from s in stringListwhere s.Contains("Tutorials") select s;

查询语法从一个From子句开始,然后是一个Range变量。在从子句结构类似,意味着从集合中的每个对象。它类似于一个foreach循环:"From rangeVariableName in IEnumerablecollection"foreach(Student s in studentList)
   在From子句之后,可以使用不同的标准查询运算符来过滤,分组和集合的元素。在LINQ中有大约50个标准查询操作符可用。在上图中,我们使用了“where”运算符(aka子句)后跟一个条件。这个条件通常用lambda表达式表示。
   LINQ查询语法总是以Select或Group子句结束。Select子句用于形成数据。您可以按原样选择整个对象,也可以仅选择其中的一些属性。在上面的例子中,我们选择了每个结果字符串元素。

LINQ方法语法

方法语法(也称为流利语法)使用Enumerable或Queryable静态类中包含的扩展方法,类似于您将如何调用任何类的扩展方法。


// string collection
IList<string> stringList = new List<string>() { "C# Tutorials","VB.NET Tutorials","Learn C++","MVC Tutorials" ,"Java"
};// LINQ Query Syntax
var result = stringList.Where(s => s.Contains("Tutorials"));


如上图所示,方法语法由扩展方法和Lambda表达式组成。扩展方法Where()在Enumerable类中定义。

小结

LINQ语句通常和EF框架一起结合使用,本文只是简单的介绍了一下linq to sql的一些语法,还有linq to xml,linq to object,linq to database等一些知识,需要读者自行去了解。加油吧。

【LINQ语句】LINQ语句相关推荐

  1. LINQ to SQL语句(4)之Join

    LINQ to SQL语句(4)之Join Join操作符 适用场景:在我们表关系中有一对一关系,一对多关系, 多对多关系等.对各个表之间的关系,就用这些实现对多个表的操作. 说明:在Join操作中, ...

  2. LINQ to SQL语句(1)之Where(抄的好)

    Where操作适用场景:实现过滤,查询等功能.说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句.Where操作包括3种形式,分别为简单形式.关 ...

  3. [导入]LINQ体验(11)——LINQ to SQL语句之Null语义和String/DateTime方法

    摘要: 这篇接着分享一下LINQ to SQL. 本篇用一些实例说明LINQ to SQL语句Null语义和String/DateTime方法.LINQ to SQL语句与SQL Server类型有些 ...

  4. LINQ体验(6)——LINQ to SQL语句之Join和Order By

    LINQ体验(6)--LINQ to SQL语句之Join和Order By Join操作 适用场景:在我们表关系中有一对一关系,一对多关系,多对多关系等.对各个表之间的关系,就用这些实现对多个表的操 ...

  5. LINQ to SQL语句(7)之Exists/In/Any/All/Contains

    Exists/In/Any/All/Contains操作符 适用场景:用于判断集合中元素 ,进一步缩小范围. Any 说明:用于判断集合中是否有元素满足 某一条件:不延迟.(若条件为空,则集合只要不为 ...

  6. LINQ to SQL语句 收藏系列

    KB-Transaction in Linq to SQL  http://blog.darkthread.net/post-2008-05-14-transaction-in-linq-to-sql ...

  7. Linq to Sql 语句全集

    LINQ to SQL语句(1)之Where Where操作 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子 ...

  8. Linq技术四:动态Linq技术 -- Linq.Expressions

    前面介绍了Linq的三个方面应用:Linq to SQL, Linq to XML和Linq to Object,这篇介绍一下动态Linq的实现方式及应用场景. 命名空间: System.Linq; ...

  9. c语言中floox的头文件,PC-1211袖珍计算机在合成氨厂生产中的应用 第五讲 循环语句(FOR-NEXT语句)...

    PC-1211袖珍计算机在合成氨厂生产中的应用 第五讲 循环语句(FOR-NEXT语句) 在化工生产中为了分析两个或两个以上参数对生产的影响往往需要进行某些有规律的重复计算.这些计算在程序中可以用赋值 ...

  10. matlab if语句多个执行举例,初学Matlab,有两个语句,if语句和switch语句,有两个例子哪位大神能帮我讲讲...

    问题描述: 初学Matlab,有两个语句,if语句和switch语句,有两个例子哪位大神能帮我讲讲 if logical_expression statements elseif logical_ex ...

最新文章

  1. DT时代下[个推3.0]遵循的四个法则
  2. 2020 年最值得学习的 5 大 AI 编程语言
  3. android ADT学习总结
  4. 逻辑判断 java_写 JS 逻辑判断,不要只知道用 if-else 和 switch
  5. a+=b不一定等于a=a+b
  6. C# 值类型与引用类型(1)
  7. [复变函数]第19堂课 5.3 解析函数在无穷远处的性质
  8. 这里有一个让你变成技术大牛的机会
  9. java生成excel中文乱码,JSP应用导出Excel报表的简单实现以及中文乱码彻底解决(HTML)...
  10. android 黄金颜色,一加手机3有哪几种颜色 一加3 薄荷金与冰川灰哪种颜色好看?...
  11. Spring学习笔记(一) 简介
  12. hdu 4609 3-idiots——FFT
  13. 同方台式计算机密码,清华同方bios默认密码
  14. 手动编译源代码安装wget
  15. Assembler messages error gcc and clang build
  16. 【渝粤教育】广东开放大学 建设工程法规 形成性考核 (32)
  17. 计算机屏幕节省电,电脑显示器如何省电
  18. 福玛特机器人评测_离子净化!福玛特E-R350W扫地机器人试玩
  19. Ubuntu管理员密码
  20. 单片机工程师如何继续提升自己?

热门文章

  1. 美国队长3:内战_隐藏的宝石:寻找美国最好的秘密线索
  2. java实现蔬菜版的大富翁游戏~~~
  3. 2021年度学习计划
  4. 新玺配资:沪指蓄势特征显著不排除挑战年内新高
  5. opencv中的cv2.getStructuringElement()
  6. 金仓kingbase数据库设置自增长
  7. android 平台上,AndroidAPP如何在Android平台上架?
  8. 面试官灵魂拷问:为什么代码规范要求 SQL 语句不要过多的 join?
  9. Golang实现事件系统
  10. SAP ERP系统PP模块计划策略2050详解