LinQ的一些基本语句

LINQ(Language Integrated Query)即语言集成查询。它是一种语言特性和API,使得你可以使用统一的方式编写各种查询,查询的对象包括xml、对象集合、SqlServer数据库等。

1、LINQ To Object      负责对象的查询

2、LINQ To XML         负责对XML的查询

3、LINQ To ADO.NET  负责数据库的查询

查询例如:

int[] numbers=new int[]{1,2,7,9,3,6}

List<int> array=new List<int>();

foreach(int temp in numbers)

{

if(temp%2==0)

{

array.Add(temp);

}

}

LINQ 查询:

int[] numbers=new int[]{1,3,5,9,2,7}

var even=numbers.where(p=>p%2==0).select(p=>p).OrderBy Descending(p=>p);//从数组中提取偶数并降序排列

even.sort();//升序

even.Reverse();//降序

Lambda表达式的进化:

C# 1.0  委托

C# 20  匿名方法

C# 3.0 Lambda表达式

委托:

delegate string ProcessString(string input);

ProcessString p=new ProcessString(Lowerlt);

foreach(string name in FoxRive)

{

console.WriteLine(p(name));

}

Private string Lowerlt(string input)

{

return input.ToLower();

}

匿名方法:

ProcessString p=new ProcessString(string input)

{

return input.ToLower();

}

foreach(string name in FoxRive)

{

console.WriteLine(p(name));

}

Lambda表达式:

ProcessString p=input=>input.ToLower();

foreach(string name in FoxRive)

{

console.WriteLine(p(name));

}

查询语句示例:

示例一:

int[] numbers=new int[]{6,4,3,2,1,9,7,8,5}

var even=numbers.where(p=>p%2==0)

.select(p=>{console.write(p.tostring())}); return p;)

foreach(var item in even)

{

console.writeline(item);

}

示例二:

int[] numbers=new int[]{6,4,3,2,1,9,7,8,5}

var even=from number in numbers

where  number%2==0)

.orderby number descending select number;

foreach(var item in even)

{

console.writeline(item);

}

复杂查询语句示例:

List<Person> p=GetFoxRiver();

var q=from a in p where a.Age<30 && a.FristName.Length=7

orderby a.Age DEscending

select new {Name=a.FristName+""+a.LastName,Age=a.Age};

foreach(var item in even)

{

console.writeline(item.Name+""+item.Age);

}

聚合类

int[] array=new int[]{1,3,7,9,2,14}

console.writeline("Max:{0}",array.Max());//返回最大值

console.writeline("Min:{0}",array.Min());//返回最小值

console.writeline("Average:{0}",array.Average());//返回平均值

var result=(from p in array where p.Startswith(‘,‘) select p).count();

console.writeline("count:{0}",result);//返回数组中总共几个数

分区类

var result=array.Take(3);//从序列开头返回指定数量,连续元素

结果:1,3,7

var result=array.Takewhere(p=>p%2==0);//满足条件就返回元素,不满足就不返回

结果:2,14

var result=array.where(p=>p%2==0).Take(1);//

结果:2

var result=array.skip(2);//跳出序列中指定数量的元素返回剩余值元素

结果:3,7,9,2,14

var result=array.skipwhere(p=>p》3);//

结果:7,9,2,14

集合类

var result=array.Distirot();//返回序列中非重复元素

生成类:

var result=Enumerable.Repeat("a",10).tolist();//生成包含一个重复值的序列

var result=Enumerable.Range(2,10).tolist();//生成一个指定范围内的序列

时间: 2024-08-26 03:15:17

LinQ的一些基本语句的相关文章

Linq to EF 和 Linq to SQL 中间Linq 产生的SQL语句

一,Linq to EF using System; using System.Runtime.CompilerServices; using System.Linq; using System.Data; namespace EntityframeworkSQL { class Program { static void Main(string[] args) { using (CustomerEntities customerEntities = new CustomerEntities()

sql 、linq、lambda 查询语句的区别

LINQ的书写格式如下: from 临时变量 in 集合对象或数据库对象 where 条件表达式 [order by条件] select 临时变量中被查询的值 [group by 条件] Lambda表达式的书写格式如下: (参数列表) => 表达式或者语句块 其中: 参数个数:可以有多个参数,一个参数,或者无参数. 参数类型:可以隐式或者显式定义. 表达式或者语句块:这部分就是我们平常写函数的实现部分(函数体). 1.查询全部 实例 Code 查询Student表的所有记录. select *

sql、linq和lambda查询语句比较inner join和group by组合使用及匿名类型的处理

使用EF自己做的小功能需要遇到inner join和group by组合使用及匿名类型的处理,搜了很多,基本不能满足自己的需要,所以总结了也实现了就自己写出来,已备查看及伙伴查询参考(一般的语句查询就不说了,网络搜索很多) 语句查询的背景(要不直接看语句故估计也够呛):主要想实现类似QQ相册的功能展示,页面展示所有相册列表,主要包括:相册里面的相册个数,相册中的某一个张照片作为相册的默认背景图,相册名,相册描述,删除和编辑功能 sql server:(这个就比较简单) select count(

获取linq生成的sql语句

命名空间:using System.Data.Objects; var query = db.TxtRes.Join(db.LangRes, a => new { id1 = a.ResID, id2 = a.ResID }, b => new { id1=b.ID,id2=b.ID }, (a, b) => new { a.ID, a.ResID, a.Lang, b.Key }); var objectQuery = query as System.Data.Objects.Obje

C# List中写出LINQ类似SQL的语句

很多时候,从一个关系表中挑出一个我们需要的元素列表采用SQL语句是再容易不过的了,其实C#的List中也可以采用类似的方法,虽然List中集成了Select(), Where()等语句,不过如果你的判断规则较为复杂,或者想要看起来一目了然,以下的方法也是可行的: 首先假设你有一个类 public class People { public string Name { get; set; } public int Age { get; set; } } 并且有一些初始化语句 List<People

请问在 .NET Core 中如何让 Entity Framework Core 在日志中记录由 LINQ 生成的SQL语句?

using dotNET.Core; using Microsoft.Extensions.Logging; using System; using System.Collections.Generic; using System.Diagnostics; using System.Text; namespace dotNET.EFCoreRepository { /// <summary> /// ef 日志 /// </summary> public class EFLogge

Linq表达树

这篇博客只能用来批判因为我刚刚学习linq对它了解只有简单的linq to sql 的语句所以来写这个博客只能说是班门弄斧了,看的下去的话就坚持看吧. 在网上看了别人的文章目前水平有限借鉴别人的思想吧. 描述:表达式树是将我们原来可以直接由代码编写的逻辑以表达式的方式存储在树状的结构里,从而可以在运行时去解析这个树,然后执行,实现动态的编辑和执行代码. 示例: void Main()  {    Expression<Func<int,int>> tree = x=>x+1;

.NET深入实战系列—Linq to Sql进阶

最近在写代码的过程中用到了Linq查询,在查找资料的过程中发现网上的资料千奇百怪,于是自己整理了一些关于Linq中容易让人困惑的地方. 本文全部代码基于:UserInfo与Class两个表,其中Class中的UserId与UserInfo中的Id对应 本文唯一访问地址:http://www.cnblogs.com/yubaolee/p/BestLinqQuery.html linq联合查询 内联查询 内联是一个实际使用频率很高的查询,它查询两个表共有的且都不为空的部分 from user in

Linq in C#

Linq是 .net framework 3.5之后才出现的技术,只有在.net framework 3.5以上的版本才能使用 使用Linq可以极大的简化我们对数据的操作,直接上图 然后上代码 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace WangXuConsole { class Progr