• 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,则是取整到十位,以此类推。 

  • 相关阅读:
    Axure学习二:基础教程
    Axure 学习一:基础知识详解参考文档
    iOS 加载动态库报错问题
    iOS 9 之 Spotlight框架
    iOS 之 新功能、扩展
    mysql慢查询
    php curl多线程抓取网页
    php读取qqwry.dat ip地址定位文件的类
    php比较加赋值语句
    yaf在windows7下32位的安装教程
  • 原文地址:https://www.cnblogs.com/huanghongbo/p/4538613.html
Copyright © 2020-2023  润新知