Linq用法笔记

作者: 小明yz | 来源:发表于2017-06-23 08:24 被阅读239次

一、什么是Linq?

LINQ即Language Integrated Query(语言集成查询),LINQ是集成到C#和Visual Basic.NET这些语言中用于提供查询数据能力的一个新特性。

LINQ是一种用来进行数据访问的编程模型,Linq可以用相同的语法访问不同的数据源,比如xml、数据库、注册表、事件日志等。

二、Linq包含哪些部分?

1、Linq to Sql组件:可以查询关系型数据库的数据,并可以提供其他操作,如检索、插入、修改、删除、排序、聚合、分区等。

2、Linq to DataSet组件:查询DataSet对象中的数据。

3、Linq to Object组件:可以查询IEnumerable或是IEnumerable 集合对象,即能够查询任何可以枚举的集合,如数组(Array和ArrayList)、泛型字典Dictinary等,以及用户自定义的集合,而不需要使用Linq提供程序或API。

4、Linq to XML组件:查询和操作XML结构的数据。

5、Linq to Entities:是 Entity Framework 的一部分并且取代 LINQ to SQL 作为在数据库上使用 LINQ 的标准机制。Entity Framework 是行业领先的对象-关系映射(ORM)系统。可以和多种数据库一起使用,并支持各种灵活、复杂的数据模型。

三、Linq的一些用法

1、简单的LINQ查询

static void Main(string[] args)

{

int[] marks = { 60, 77, 82, 46, 59, 98, 100, 84 };//定义一个数组

var good = from m in marks//使用LINQ找到所有数值大于等于60的数字

where m >= 60

select m;

foreach (int mark in good)//循环每一个结果

{

Console.WriteLine(mark);//输出结果

}

}

2、使用Lambda表达式的LINQ查询

static void Main(string[] args)

{

int[] marks = { 60, 77, 82, 46, 59, 98, 100, 84 };

var good = marks.Where(m => m >= 60);//使用Lambda表达式查询数值大于等于60的数字

foreach (int mark in good)//循环每一个结果

{

Console.WriteLine(mark);//输出结果

}

}

3、使用LINQ查询对象集合

class Program

{

static void Main(string[] args)

{

List students = new List//申明Student对象的集合

{

new Student{ StudentID=1, Sex=true, Name="小明", Birthday=Convert.ToDateTime("1984-1-1")},

new Student{ StudentID=2, Sex=false, Name="小张", Birthday=Convert.ToDateTime("1983-5-1")},

new Student{ StudentID=3, Sex=true, Name="小王", Birthday=Convert.ToDateTime("1983-2-15")},

new Student{ StudentID=4, Sex=false, Name="小丽", Birthday=Convert.ToDateTime("1985-3-8")}

};

//接下来使用LINQ查询所有年龄小于25岁的男性

var names = from s in students

where s.Sex == true&&s.GetAge()<25 //调用对象的方法

select s.Name;

foreach (string name in names)//循环输出结果

{

Console.WriteLine(name);

}

}

}

public class Student  //定义Student类

{

//以下是定义类中属性

public string Name { get; set; }

public int StudentID { get; set; }

public bool Sex { get; set; }

public DateTime Birthday { get; set; }

//以下是定义类中的方法

public int GetAge()

{

return DateTime.Now.Year - Birthday.Year;

}

}

四、Linq有什么好处?

1、容易上手,学习成本低

2、可以很大程度上减少代码量。

3、更快开发错误更少的应用程序。

4、可以很容易的合并数据源。

5、让新开发者开发效率更高。

6、任何对象或数据源都可以定制实现Linq适配器,为数据交互带来真正方便。

欢迎关注我的公众号(同步更新文章):DoNet技术分享平台

阅读原文

相关文章

  • Linq用法笔记

    一、什么是Linq? LINQ即Language Integrated Query(语言集成查询),LINQ是集成...

  • Linq

    Linq查询的基本用法和介绍(m为集合中每个元素的别名) Linq的Lambda表达式(因为委托是一个参数,所以可...

  • Linq的用法总结

    一.linq的适用类型 二.linq的好处方便我们对保存的数据进行筛选,把数据保存为自己想要的排序,或者快速筛选出...

  • LINQ

    什么是linq? linq是语言集成查询。 linq主要包含三部分 linq to xml linq to obj...

  • Lession12-LINQ

    LINQ简介 编写一个扩展方法 LINQ查询方法 LINQ查询的延迟加载 Linq标准查询操作符 LinqToXML

  • LINQ入门

    linq是语言集成查询。 linq to object :面向对象的查询。 linq to xml:针对xml查询...

  • Laravel 开发笔记

    Laravel 笔记 前言 记录 Laravel 开发中的问题,及笔记。 用法 Validator 类的用法 用法...

  • LINQ表达式用法整理

    收集一些Linq表达式中的一些比较常用的写法,希望能给大家工作当中带来一些便利。 1. Where子句条件过滤结果...

  • (转).NET面试题系列[14] - LINQ to SQL与I

    LINQ to Object和LINQ to SQL有何区别? LINQ to SQL可以将查询表达式转换为SQL...

  • linq语句

    https://www.yiibai.com/linq/linq_filtering_operators.html...

网友评论

    本文标题:Linq用法笔记

    本文链接:https://www.haomeiwen.com/subject/dbiqcxtx.html