grails框架中查询聚合函数,如条数,总额

def query=
        {
             //交易完毕时间  tradeDonedate
             if(params.tradeDonedateStart){
                 gt("tradeDonedate", Date.parse("yyyy-MM-dd",params.tradeDonedateStart))
             }
             if(params.tradeDonedateEnd){
                 lt("tradeDonedate", Date.parse("yyyy-MM-dd",params.tradeDonedateEnd)+1)
             }

            //先以商户编号为准
             if(params.batchBizid){
                     eq("batchBizid",params.batchBizid)
             }else{
                 //如果没有输入商户编号,而输入的是商户名称
                 if(params.batchBizname){
                     def cmCustomer = CmCustomer.createCriteria().list{
                     eq("type","C")
                     like("name","%"+params.batchBizname+"%")
                     }

                 //使用in的时候,传递参数为一个结果集,而非一个逗号分割的字符串
                    if(cmCustomer.size()>0){
                        'in'("batchBizid",cmCustomer.customerNo)
                     }
                 }else{
                    
                 }
             }
             if(params.tradeType&&params.tradeType!="-1"){
                 eq("tradeType",params.tradeType)
             }
           
             if(params.tradeCardname){
                 like("tradeCardname","%"+params.tradeCardname+"%")
             }
             if(params.tradeCardnum){
                 eq("tradeCardnum",params.tradeCardnum)
             }
             if(params.tradeAccountname!=null && params.tradeAccountname!=""){
            
               def bankNames =  findTradeAccountnames(params.tradeAccountname);
                 //println  bankNames;
                'in'("tradeAccountname",bankNames);
             }
             if(params.tradeAccounttype){
                 eq("tradeAccounttype",params.tradeAccounttype)
             }
             if(params.batchId){

                 eq("batch",TbAgentpayInfo.get(params.batchId))
             }
             if(params.id){
                 eq("id",params.id )
             }
             /*if(params.tradeFeestyle!="-1" && params.tradeFeestyle!=null){
                 if(params.tradeFeestyle=="T")
                    eq("tradeFeestyle",params.tradeFeestyle)
                 else
                    isNull("tradeFeestyle")
             }*/
            
             /*if(params.tradeRemark2!="" && params.tradeRemark2!=null){
                 like("tradeRemark2","%"+params.tradeRemark2+"%")
             }*/
             if(params.batchStatus&&params.batchStatus!="-1"){
                 "in"("tradeStatus",params.batchStatus)
             }
            order("id","desc")
        }

 

def  results = MyDomain.createCriteria().get {
            and query
//            eq('tradeType', 'payment')
            projections {

             rowCount()

                sum('tradeAmount')
                  sum('tradeFee')
                sum('tradeAccamount')
            }
        }

这里要注意一下,这个results 返回的是一个数组,而非是对象的list,如果要取值的话,比如记录条数,则为results[0].

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值