首页 > 其他 > 详细

OAF中trunc函数的使用(转)

时间:2015-05-29 17:14:56      阅读:264      评论:0      收藏:0      [点我收藏+]

原文地址:OAF中trunc函数的使用

需求:在做OAF开发时,经常会需要查询功能,由于需求的不同,往往不能使用OAF标准的查询功能,需要自己客户化实现查询功能,而在查询功能中,经常会遇到查询的时间范围,要查询从。。。开始,到。。。结束这段时间内的结果,所以会经常在AM的实现类里面给vo增加where语句限制,往往是获取某个查询条件,然后该查询条件大于等于开始时间,小于等于结束时间,例如:

if (searchSubmitDateFrom != null && !("".equals(searchSubmitDateFrom))) {           
    whereClause.append(" AND submit_date >= :");
    whereClause.append(++bindCount);
    params.addElement(searchSubmitDateFrom);
}

if (searchSubmitDateTo != null && !("".equals(searchSubmitDateTo))) {           
    whereClause.append(" AND submit_date <= :");
    whereClause.append(++bindCount);
    params.addElement(searchSubmitDateTo);
}

 

这中写法,问题来了,当运行时,如果提交日期等于结束日期的记录往往是查询不到的,因为日期的时分秒引起的。所以这种情况要使用trunc函数对时间进行处理,把时间的时分秒给去除掉,例如:

if (searchSubmitDateTo != null && !("".equals(searchSubmitDateTo))) {           
    whereClause.append(" AND trunc(submit_date) <= trunc(:");
    whereClause.append(++bindCount + ")");
    params.addElement(searchSubmitDateTo);
}

if (searchReqPickDateFrom != null && !("".equals(searchReqPickDateFrom))) {
    whereClause.append(" AND trunc(require_pick_date) >= trunc(:");
    whereClause.append(++bindCount + ")");
    params.addElement(searchReqPickDateFrom);
}       

再次运行,不会出现类似问题。

trunc函数用法:

1.TRUNC(for dates)

描述:TRUNC函数为指定元素而截去的日期值。

语法:TRUNC(date[,fmt]),其中date 一个日期值,fmt 日期格式,该日期将由指定的元素格式所截去。忽略它则由最近的日期截去。

使用情况:

TRUNC(TO_DATE(24-Nov-1999 08:00 pm),dd-mon-yyyy hh:mi am) = 24-Nov-1999 12:00:00 am
TRUNC(TO_DATE(24-Nov-1999 08:37 pm,dd-mon-yyyy hh:mi am),hh) =24-Nov-1999 08:00:00 am 
trunc(sysdate,yyyy) --返回当年第一天.
trunc(sysdate,mm) --返回当月第一天. 
trunc(sysdate,d) --返回当前星期的第一天. 

2.TRUNC(for number)

描述:TRUNC函数返回处理后的数值,其工作机制与ROUND函数极为类似,只是该函数不对指定小数前或后的部分做相应舍入选择处理,而统统截去。

语法:TRUNC(number[,decimals]),其中,number 待做截取处理的数值,decimals 指明需保留小数点后面的位数。可选项,忽略它则截去所有的小数部分。

使用情况:

TRUNC(89.9852) = 89.98 
TRUNC(89.985) = 89 
TRUNC(89.985-1) = 80 

注意:注意:第二个参数可以为负数,表示为小数点左边指定位数后面的部分截去,即均以0记。与取整类似,比如参数为1即取整到十分位,如果是-1,则是取整到十位,以此类推。 

OAF中trunc函数的使用(转)

原文:http://www.cnblogs.com/huanghongbo/p/4538613.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!