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

  • 相关阅读:
    mysql/mariadb基于ssl的主从复制
    原创工具binlog2sql:从MySQL binlog得到你要的SQL
    [转]MySQL DBA面试全揭秘
    mysql my.cnf 配置建议
    mysql配置文件 /etc/my.cnf 详细解释
    [转]expect实现ssh自动交互
    Linux中的lo回环接口详细介绍
    Docker最全教程——从理论到实战(五)
    Docker最全教程——从理论到实战(四)
    Docker最全教程——从理论到实战(一)
  • 原文地址:https://www.cnblogs.com/huanghongbo/p/4538613.html
Copyright © 2020-2023  润新知