MicroOrm.Net(7) Table.Query() - Group By & Having

MicroOrm.Net主页:

http://code.google.com/p/micro-orm-net/

MicroOrm.Net系列随便目录总览:

http://www.cnblogs.com/mapserver/archive/2012/04/07/2436129.html

 

本文我们来讲解MicroOrm.Net的Group By和Having的用法,请看Group By的api:

Query GroupBy(params Column[] columns)

 

方法的参数只有Column集合这一种类型,用法很简单,请看下面的代码:

db.OrderDetail.Query()
        .GroupBy(db.OrderDetail.ProductId)

 

熟悉SQL的同学都知道,在Group By和Select配合使用的时候,出现在Group By子句中的Column可以被直接Select,没有出现在Group By子句中的Column必须经过聚合后才能被Select

db.OrderDetail.Query()

        .GroupBy(db.OrderDetail.ProductId)

        .Select(db.OrderDetail.OrderId)

上面的代码将会出错,因为Select子句里的OrderDetail.OrderId未出现在Group By子句中,同时也没有被聚合。

上面的代码等价于如下的SQL:

select OrderId from OrderDetail group by ProductId 

执行这句SQL,SQL Server报错信息如下:

Msg 8120, Level 16, State 1, Line 1
Column 'OrderDetail.OrderId' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.

 

Group By时,Select使用Column聚合函数代码如下:

db.OrderDetail.Query()
        .GroupBy(db.Order.ProductId)
        .Select(db.Order.ProductId, db.OrderDetail.Qty.Sum().As("Sum"))

 

Having一般都和Group By搭配来使用,上面我们演示了Group By的用法,我们再来看看Having的用法,至于到底什么是Having,请大家自己去Google

Having方法的api:

Query Having(Expression criteria)

 

在Group By子句中出现的Column,能直接在Having方法Expression里使用;未出现在Group By子句里的Column,要在Having方法Expression里使用时,必须要聚合。这和上面Group By后Select一样。

db.OrderDetail.Query()

        .GroupBy(db.OrderDetail.ProductId)

        .Having(db.OrderDetail.Qty > 0)

上面的代码将会出错,因为Having方法里的Expression参数用了 OrderDetail.Qty,但是它并未出现在Group By子句中。

 

Group By时,Having使用Column聚合函数代码如下:

db.OrderDetail.Query()
        .GroupBy(db.OrderDetail.ProductId)
        .Having(db.OrderDetail.Qty.Sum > 0)

 

MicroOrm.Net支持的聚合函数有:Sum、Min、Max、Avg

 

posted @ 2012-04-12 00:41  mapserver  阅读(741)  评论(0编辑  收藏  举报