grails框架中查询聚合函数,如条数,总额
2012-04-20 10:01
225 查看
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&¶ms.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&¶ms.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].
{
//交易完毕时间 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&¶ms.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&¶ms.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].
相关文章推荐
- Ext.js5表单—(triggers触发器)(baseCSSPrefix)(specialkey)利用Ext.js提供的框架创建自己的表单(查询表单)(51)
- 使用富盛Sbo-Addon程序开发框架轻松开发模态单据选择查询功能实例
- grails的criteria和hql查询
- Yii框架查询Mongodb并页面显示问题
- 基于ExtJs框架实现高级查询界面的代码
- 基于bbossgroups持久层框架实现数据库分页查询
- MyBatis框架学习(六)-MyBatis的多表查询
- 缓存框架Ehcache,减少数据库频繁查询
- 使用聚合函数group by后面必须要带着所有要查询的列,但是我只想根据group by后面的第一个列进行分组,怎么办? [
- Django框架中数据的连锁查询和限制返回数据的方法
- 【MyBatis框架】高级映射-一对多查询
- 聚合函数,分组查询,连接查询综合样例
- Hql中的基本查询语句(含聚合函数)
- 使用聚合函数查询
- 【SpringMVC整合MyBatis】商品查询工程框架配置
- phalco框架的查询
- 在Java的Hibernate框架中对数据库数据进行查询操作
- 采用框架Spring+SpringMVC+mybatis搭建框架,完成省市区级联查询
- 框架之 hibernate之各种查询
- mybatis 框架 的应用之二(批量添加、实现分页查询)