LINQ 标准查询操作符(2)


using (NorthwindDataContext db = new NorthwindDataContext())
{
//方法语法
var q =
db.Employees
.Select(e => e.FirstName)
.ToList();
q.Reverse();
foreach (var item in q)
{
Console.WriteLine(item);
}
}


四、联接操作符
联接是指将一个数据源对象与另一个数据源对象进行关联或者联合的操作。这两个数据源对象通过一个共同的值或者属性进行关联。
LINQ有两个联接操作符:Join和GroupJoin。
1. Join
Join操作符类似于T-SQL中的inner join,它将两个数据源相联接,根据两个数据源中相等的值进行匹配。例如,可以将产品表与产品类别表相联接,得到产品名称和与其相对应的类别名称。以下的代码演示了这一点:

复制代码 代码如下:


using (NorthwindDataContext db = new NorthwindDataContext())
{
db.Log = Console.Out; //将生成的T-SQL语句输出到控制台中
//查询语法
var query =
from p in db.Products
join c in db.Categories on p.CategoryID equals c.CategoryID
where p.CategoryID == 1
select p;
//方法语法
var q =
db.Products
.Join
(
db.Categories,
p => p.CategoryID,
c => c.CategoryID,
(p, c) => p
)
.Where(p => p.CategoryID == 1);
foreach (var item in query)
{
Console.WriteLine(item.ProductName);
}
}


以上代码为表述清晰加入了一个条件“where p.CategoryID == 1”,即仅返回产品类别ID为1的所有产品。
2. GroupJoin
GroupJoin操作符常应用于返回“主键对象-外键对象集合”形式的查询,例如“产品类别-此类别下的所有产品”。以下的代码演示了这一点:

复制代码 代码如下:


using (NorthwindDataContext db = new NorthwindDataContext())
{
db.Log = Console.Out; //将生成的T-SQL语句输出到控制台中
//查询语法
var query =
from c in db.Categories
join p in db.Products on c.CategoryID equals p.CategoryID into r
select new
{
c.CategoryName,
Products = r
};
//方法语法
var q =
db.Categories
.GroupJoin
(
db.Products,
c => c.CategoryID,
p => p.CategoryID,
(c, p) => new
{
c.CategoryName,
Products = p
}
);
foreach (var item in query)
{
Console.WriteLine("{0} =>", item.CategoryName);
foreach (var p in item.Products)
{
Console.WriteLine(p.ProductName);
}
Console.WriteLine("----------------------------------------------");
}
}


五、分组操作符
分组是根据一个特定的值将序列中的元素进行分组。LINQ只包含一个分组操作符:GroupBy。
下面的示例中使用了产品表,以CategoryID作为分组关键值,按照产品类别对产品进行了分组。

复制代码 代码如下:


using (NorthwindDataContext db = new NorthwindDataContext())
{
db.Log = Console.Out; //将生成的T-SQL语句输出到控制台中
//查询语法
var query =
from p in db.Products
group p by p.CategoryID;
//方法语法
var q =
db.Products
.GroupBy(p => p.CategoryID);
foreach (var item in query)
{
Console.WriteLine("{0} =>", item.Key);
foreach (var p in item)
{
Console.WriteLine(p.ProductName);
}
Console.WriteLine("----------------------------------------------");
}
}


执行GroupBy得到的序列中包含的元素类型为IGrouping<TKey?, T>,其Key属性代表了分组时使用的关键值,遍历IGrouping<TKey?, T>元素可以读取到每一个T类型。在此示例中,对应的元素类型为IGrouping<int?, Products>,其Key属性即为类别ID,遍历它可以读取到每一个产品对象。
六、串联操作符
串联是一个将两个集合联接在一起的过程。在LINQ中,这个过程通过Concat操作符来实现。
在下面的示例中,将会把类别名称串联在产品名称之后:

复制代码 代码如下:


using (NorthwindDataContext db = new NorthwindDataContext())
{
db.Log = Console.Out; //将生成的T-SQL语句输出到控制台中
//方法语法
var q =
db.Products
.Select(p => p.ProductName)
.Concat
(
db.Categories.Select(c => c.CategoryName)
);
foreach (var item in q)
{
Console.WriteLine(item);
}
}


七、聚合操作符
聚合函数将在序列上执行特定的计算,并返回单个值,如计算给定序列平均值、最大值等。共有7种LINQ聚合查询操作符:Aggregate、Average、Count、LongCount、Max、Min和Sum。
1. Aggregate
Aggregate操作符对集合值执行自定义聚合运算。例如,需要列出所有产品类别清单,每个类别名称之间用顿号连接。以下的代码演示了这一过程:

复制代码 代码如下:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wjjxpz.html