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();//生成一个指定范围内的序列
LinQ的一些基本语句的更多相关文章
- 浅谈sql 、linq、lambda 查询语句的区别
浅谈sql .linq.lambda 查询语句的区别 LINQ的书写格式如下: from 临时变量 in 集合对象或数据库对象 where 条件表达式 [order by条件] select 临时变量 ...
- sql 、linq、lambda 查询语句的区别
LINQ的书写格式如下: from 临时变量 in 集合对象或数据库对象 where 条件表达式 [order by条件] select 临时变量中被查询的值 [group by 条件] Lambda ...
- linq直接执行sql语句
1.ExecuteQuery方法 看命名,我们很容易联想到ado.net里熟悉的Command的ExecuteNonQuery方法,但是VS的智能提示告诉我们这个方法返回的是一个泛型集合,应该&quo ...
- sql、linq和lambda查询语句比较inner join和group by组合使用及匿名类型的处理
使用EF自己做的小功能需要遇到inner join和group by组合使用及匿名类型的处理,搜了很多,基本不能满足自己的需要,所以总结了也实现了就自己写出来,已备查看及伙伴查询参考(一般的语句查询就 ...
- C# List中写出LINQ类似SQL的语句
很多时候,从一个关系表中挑出一个我们需要的元素列表采用SQL语句是再容易不过的了,其实C#的List中也可以采用类似的方法,虽然List中集成了Select(), Where()等语句,不过如果你的判 ...
- 获取linq生成的sql语句
命名空间:using System.Data.Objects; var query = db.TxtRes.Join(db.LangRes, a => new { id1 = a.ResID, ...
- linq查询时查询语句中附带多个查询时“已有打开的与此 Command 相关联的 DataReader,必须首先将它关闭”
主要原因是因为EF采用的 DataReader来进行数据的存储,此时connection使用的是同一个. 例如: list = _tzNewsService.GetAll().Where(w => ...
- 请问在 .NET Core 中如何让 Entity Framework Core 在日志中记录由 LINQ 生成的SQL语句?
using dotNET.Core; using Microsoft.Extensions.Logging; using System; using System.Collections.Generi ...
- 打印Linq生成的SQL语句
var t1 = source.OrderBy<T>(orderby).Skip<T>(_skip).Take<T>(_take); var t2 = t1.ToO ...
随机推荐
- 在Windows的Tomcat环境下部署Solr 4.7.0
主要步骤如下: 1.下载solr-4.7.0.tgz; 2.解压缩solr-4.7.0.tgz,解压后目录结构如下: 3.将example/webapps目录下的solr.war复制到tomcat的w ...
- IOS开发中滑动页面时NSTimer停止的问题
我们在做倒计时的时候,发现当你手指按着屏幕不放,拖动tableView滑动的时候,写在cell上得倒计时停止倒计时,松开继续倒计时.研究发现就是拖动tableView滑动时,NSTimer停止了. 这 ...
- 深入理解Java中的继承
对于面向对象的程序设计而言,每一个程序员都应该去了解Java中的封装,继承和多态,那么我今天来说的主要是以继承为核心的主题. 一.关于对继承的理解. 继承是面向对象的三大特性之一,是java中实现代码 ...
- ASP.NET中树型DropDownList的绑定
首先设计好数据库,假设数据库有三个字段Id,ParentId,Name.ParentId是树性结构必须的,就是节点的父节点id,假设跟节点id都是0.下面就可以绑定了! 思路应该很简单,就是先绑定根节 ...
- HDU 4857 Couple doubi(找循环节)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4861 解题报告:桌子上有k个球 ,第i个球的价值wi = 1^i+2^i+...+(p-1)^i (m ...
- 关于visio 2007导入独立图库
很多作网络拓扑或服务器系统拓扑时,我们都会找到相关的Visio图库来画,但很多时候我们不知如何才能够直接导入,下面是我自己的导入方式,供大家参考下! 打开07Visio,自动加载设置: 工具--> ...
- Largest Divisible Subset
Given a set of distinct positive integers, find the largest subset such that every pair (Si, Sj) of ...
- ListBox1控件
前台: <div> <asp:ListBox ID="ListBox1" runat="server" AutoPostBack=" ...
- python操作Excel读写--使用xlrd
一.安装xlrd模块 到python官网下载http://pypi.python.org/pypi/xlrd模块安装,前提是已经安装了python 环境. 二.使用介绍 1.导入模块 import x ...
- Greedy:Packets(POJ 1017)
装箱问题1.0 题目大意:就是一个工厂制造的产品都是正方形的,有1*1,2*2,3*3,4*4,5*5,6*6,高度都是h,现在要包装这些物品,只能用6*6*h的包装去装,问你怎么装才能使箱子打到最小 ...