grails检索mongodb

①condictions检索:

检索:
PaperLog.collection.find(condictions) .sort([updateTime:-1]). limit(params.rows.toInteger()).skip((params.page.toInteger() - 1) * params.rows.toInteger()).each{}
.sort([updateTime:-1]): 按时间updateTime降序排列
limit(params.rows.toInteger()).skip((params.page.toInteger() - 1) * params.rows.toInteger()): 设置分页

1.检索时间
import java.text.SimpleDateFormat

def dfDate = new SimpleDateFormat("yyyy-MM-dd")
def df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")

Map condictions = [:]
if(params.dateFrom && params.dateTo){
   condictions.put("ut", ["\$gte":df.parse(params.dateFrom+" 00:00:00"),"\$lte":df.parse(params.dateTo+" 00:00:00")])
  }else{
   if(params.dateFrom) {
    condictions.put("ut", ["\$gte":df.parse(params.dateFrom+" 00:00:00")])
   }
   if(params.dateTo) {
    condictions.put("ut", ["\$lte":df.parse(params.dateTo+" 00:00:00")])
   }
  }

时间的显示格式化:(显示为+8时区时间,而不是格林威治时间)
   def createDate
    if(it?.updateTime){
    createDate = df.format(it?.updateTime)
    }
2.模糊检索名称
def serTitle = params.title
condictions.put("title",~/$serTitle/)

3.包含检索
def seniorCourse = [pc, pC, se, mt]
condictions.put("course", ["\$in": seniorCourse])

4.检索ID
condictions.put("_id", new ObjectId(it.paperId))
5.不包含检索
conditions.put("del",["\$ne":false])


②createcriteria检索



def resultList = TestPaper.createCriteria().list([max:Integer.parseInt(params.rows),offset:Integer.parseInt(params.rows)*(Integer.parseInt(params.page)-1)]){    
if(params.course){
     eq("course", params.course)
}
if(params.status){
  eq("status", params.status.toInteger())
}
order("updateDate","desc")
}

def resultList = TestPaper.createCriteria().list([max:Integer.parseInt(params.rows),offset:Integer.parseInt(params.rows)*(Integer.parseInt(params.page)-1)]){    
if(params.course){
     eq("course", params.course)
}
if(params.status){
  eq("status", params.status.toInteger())
}
order("updateDate","desc")
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值