OAF中trunc函数的使用(转)

原文地址: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,则是取整到十位,以此类推。 

原文地址:https://www.cnblogs.com/huanghongbo/p/4538613.html