LINQ标准查询操作符(二)——Join、GroupJoin、GroupBy、Concat、
联接是指将一个数据源对象与另一个数据源对象进行关联或者联合的操作。这两个数据源对象通过一个共同的值或者属性进行关联。
LINQ有两个联接操作符:Join和GroupJoin。
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的所有产品。
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,其Key属性代表了分组时使用的关键值,遍历IGrouping元素可以读取到每一
个T类型。在此示例中,对应的元素类型为IGrouping,其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);
-
}
- }
|