Linq的基础2
var 构建匿名类型1 = from c in ctx.GetTable<Customers>()
select new
{
城市 = c.City,
名字 = c.Name
};
var 构建匿名类型2 = from emp in ctx.GetTable<Customers>()
select new
{
城市 = emp.City,
名字 = emp.Name
};
var 多条件 = from c in ctx.GetTable<Customers>()
where c.Name == "Jay" && c.City == "雷州"
select new
{
名字 = c.City,
城市 = c.City
};
var 排序 = from c in ctx.GetTable<Customers>()
where c.City == "雷州"
orderby c.Name descending, c.City ascending
select new
{
名字 = c.Name,
城市 = c.City
};
//按照每页 10 条记录,查询第二页的顾客
var 分页 = (from c in ctx.GetTable<Customers>() select c).Skip(10).Take(10);
//根据顾客的国家分组,查询顾客数大于 5 的国家名和顾客数
var 一般分组 = from c in ctx.GetTable<Customers>()
group c by c.City into g
where g.Count() > 5
orderby g.Count() descending
select new
{
国家=g.Key,
顾客数=g.Count()
};
//根据国家和城市分组,查询顾客覆盖的国家和城市
var 匿名类型分组 = from c in ctx.GetTable<Customers>()
group c by new { c.City, c.Name } into g
orderby g.Key.City, g.Key.Name
select new
{
国家 = g.Key.Name,
城市 = g.Key.City
};
var 过滤相同项 = (from c in ctx.GetTable<Customers>() orderby c.Name select c.Name).Distinct();
var 连接并且过滤相同项 = (from c in ctx.GetTable<Customers>()
where c.City.Contains("A")
select c)
.Union(from c in ctx.GetTable<Customers>()
where c.Name.StartsWith("A")
select c).OrderBy(c => c.City);
var 连接并且不过滤相同项 = (from c in ctx.GetTable<Customers>()
where c.City.Contains("A")
select c).Concat
(from c in ctx.GetTable<Customers>() where c.City.StartsWith("A") select c)
.OrderBy(c => c.City);
//查询城市是 A 打头的顾客和城市包含 A 的顾客的交集,并按照顾客名字排序
var 取相交项 = (from c in ctx.GetTable<Customers>()
where c.City.Contains("A")
select c).Intersect
(from c in ctx.GetTable<Customers>()
where c.City.StartsWith("A")
select c).OrderBy(c => c.City);
//查询城市包含 A 的顾客并从中删除城市以 A 开头的顾客,并按照顾客名字排序
var 排除相交项 = (from c in ctx.GetTable<Customers>()
where c.City.StartsWith("A")
select c).Except
(from c in ctx.GetTable<Customers>()
where c.Name.StartsWith("A")
select c).OrderBy(c => c.Name);
//查询订单数超过 5 的顾客信息
var 子查询 = from c in ctx.GetTable<Customers>()
where
(from o in ctx.GetTable<Customers>()
group o by o.CustomerID into o
where
o.Count() > 5
select o.Key).Contains(c.CustomerID)
select c;
//查询指定城市中的客户
var in操作 = from c in ctx.GetTable<Customers>()
where new string[] { "B", "A", "C" }.Contains(c.City)
select c;
//内连接,没有分类的产品查询不到
var innerjoin = from p in ctx.GetTable<Customers>()
join c in ctx.GetTable<Customers>()
on p.CustomerID equals c.CustomerID
select p.Name;
//外连接,没有分类的产品也能查询到
var leftjoin = from p in ctx.GetTable<Customers>()
join c in ctx.GetTable<Customers>()
on p.City equals c.City
into pro
from x in pro.DefaultIfEmpty()
select p.Name;
var 单结果集存储过程 =
from c in ctx.sp_singleresultset()
where c.Name.StartsWith("A")
select c;
var 多结果集存储过程 = ctx.sp_multiresultset();
var Customer = 多结果集存储过程.GetResult<Customers>();
var Employees = 多结果集存储过程.GetResult<Employee>();
Linq的基础2的更多相关文章
- LinQ 语法基础
LINQ (Language-Integrated Query,语言集成查询). LINQ to Objects.LINQ to SQL.LINQ to DataSet和LINQ to XML,它们分 ...
- C#语法之Linq查询基础二
上篇C#语法之Linq查询基础一基本把Linq介绍了一下,这篇主要是列举下它的几个常见用法. 在用之前先准备些数据,新建了两个类Student.Score,并通过静态方法提供数据. using Sys ...
- LINQ查询基础
一.什么是LINQ LINQ是Language Integrate Query的缩写,意为语言集成查询,是微软在.Net Framework 4.5版中推出的主要特性之一. 它为开发人员提供了统一的数 ...
- C#语法之Linq查询基础一
Linq做.Net开发的应该都用过,有些地方很复杂的逻辑用Linq很方便的解决.对于Linq to object.Linq to xml.Linq to sql.Linq to Entity(EF)都 ...
- Linq 操作基础
参考资料: LINQ系列:LINQ to DataSet的DataTable操作 List<T>转换为DataTable C# DataTable 和List之间相互转换的方法 Linq中 ...
- Linq一 基础知识
1.什么是Linq 他是VS2008(.net framework 3.5)之后一项重大的突破 全程Lnaguage Integrated Query,可以成为数据迭代器. 主要有以下5大块组成: L ...
- Linq语句基础
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- LINQ的基础使用方法
//新建一个项目 //项目下新建一个App_Code文件夹 //在文件夹内添加一个LINQ TO SQL,这个操作就相当于创建了一个实体类 //连接数据库后把表拖入到服务器资源管理器中 //创建数据访 ...
- [.net 面向对象编程基础] (19) LINQ基础
[.net 面向对象编程基础] (19) LINQ基础 上两节我们介绍了.net的数组.集合和泛型.我们说到,数组是从以前编程语言延伸过来的一种引用类型,采用事先定义长度分配存储区域的方式.而集合是 ...
随机推荐
- linuxmit下git安装和初级使用
一.安装 sudo apt-get install git 二.配置 git config --global user.name "Your Name" git config -- ...
- 浅析 JavaScript 组件编写
之前因项目需要也编写过一些简单的JS组件,大多是基于JQuery库的,一直也没有过总结,导致再次写到的时候还去Google, 近日看到一个文章总结的挺好,拿过整理一下做个备忘. 此次同样是基于jque ...
- table行转列
table行转列 摘要 在使用ews调用exhange的收件箱的并在h5页面显示邮件详情的时候,因为返回的每封邮件的内容都是htmlbody,没有textbody.每封邮件又没什么规律,用正则表达式来 ...
- 使用OpenSSL生成证书
使用OpenSSL生成证书 下载安装openssl,进入/bin/下面,执行命令(把ssl目录下的openssl.cnf 拷贝到bin目录下)1.首先要生成服务器端的私钥(key文件):openssl ...
- 关于java.sql.SQLRecoverableException: Closed Connection异常的解决方案(转)
在项目中碰到了一个应用异常,从表象来看应用僵死.查看Weblogic状态为Running,内存无溢出,但是出现多次线程堵塞.查看Weblogic日志,发现程序出现多次Time Out. 我们知道,We ...
- 完整的拆分nginx访问日志
<pre name="code" class="html"> 10.168.255.134 [09/Oct/2016:15:28:52 +0800] ...
- 【转】adb push&pull bug --- Permission denied----不错
原文网址:http://blog.csdn.net/hengkong_horse/article/details/8708076 问题背景: adb push E:\\rrr.txt /data/ ...
- uva10245-The Closest Pair Problem(平面上的点分治)
解析:平面上的点分治,先递归得到左右子区间的最小值d,再处理改区间,肯定不会考虑哪些距离已经大于d的点对,对y坐标归并排序,然后从小到大开始枚举更新d,对于某个点,x轴方向只用考虑[x-d,x+d]( ...
- Hdu5381-The sum of gcd(莫队)
题意我就不说了 解析: 莫队,先预处理出以i为右端点的区间的gcd值,有一些连续的区间的gcd值是相同的,比如[j,i],[j+1,i],[j+2,i]的gcd值是相同的,我们可以把[j,j+2] ...
- Java日志终极指南
Java日志基础 Java使用了一种自定义的.可扩展的方法来输出日志.虽然Java通过java.util.logging包提供了一套基本的日志处理API,但你可以很轻松的使用一种或者多种其它日志解决方 ...