linq语句大全_第一范式第二范式第三范式的区别

linq语句大全_第一范式第二范式第三范式的区别LINQ(LanguageIntegratedQuery)是C#和VB.NET中的统一查询语法,用于保存和检索不同来源的数据

前言

   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提供程序可用的任何其他格式的数据。

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 stringList
            where s.Contains("Tutorials") 
            select s;

linq语句大全_第一范式第二范式第三范式的区别

   查询语法从一个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"));

linq语句大全_第一范式第二范式第三范式的区别
如上图所示,方法语法由扩展方法和Lambda表达式组成。扩展方法Where()在Enumerable类中定义。

小结

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

今天的文章linq语句大全_第一范式第二范式第三范式的区别分享到此就结束了,感谢您的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:http://bianchenghao.cn/75614.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注