Oracle对日期格式处理(小记)

1.对年月日取值

SELECT
    TO_CHAR( TO_DATE( T.READ_DATE, 'yyyy-mm-dd' ), 'yyyy' ) YEAR,
    TO_CHAR( TO_DATE( T.READ_DATE, 'yyyy-mm-dd' ), 'q' ) QUARTER,
    INITCAP(
    TO_CHAR( TO_DATE( T.READ_DATE, 'yyyy-mm-dd' ), 'mon', 'nls_date_language=american' )) MONTHS_EN,
    TO_CHAR( TO_DATE( T.READ_DATE, 'yyyy-mm-dd' ), 'mm' ) MONTHS,
    TO_CHAR( TO_DATE( T.READ_DATE, 'yyyy-mm-dd' ), 'yyyy-mm' ) MONTHS_DAY,
    TO_CHAR( TO_DATE( T.READ_DATE, 'yyyy-mm-dd' ), 'mm/dd' ) MONTHS_DATE,
    TO_CHAR( TO_DATE( T.READ_DATE, 'yyyy-mm-dd' ), 'W' ) WEEK_NO,
    TO_CHAR( TO_DATE( T.READ_DATE, 'yyyy-mm-dd' ), 'iw' ) WEEK
FROM
    TABLE_NAME T

------------------------------------------------------------------------------------------

2.日期差异

LocalDate startDate = LocalDate.now().minusMonths(12);
LocalDate endDate = LocalDate.now();
ChronoUnit.YEARS.between(startDate, endDate);//年
ChronoUnit.MONTHS.between(startDate, endDate);//月
ChronoUnit.WEEKS.between(startDate, endDate);//周
ChronoUnit.DAYS.between(startDate, endDate);//天
ChronoUnit.HOURS.between(startDate, endDate);//小時
ChronoUnit.MINUTES.between(startDate, endDate);//分鐘
ChronoUnit.SECONDS.between(startDate, endDate);//秒
----------------------------------------------------

3.根据日期区间遍历所有日期SQL(Oracle)

SELECT
     ADD_MONTHS( SYSDATE,-1 ) + ROWNUM - 1 AS DATAS
FROM
     DUAL 
CONNECT BY ROWNUM <= TRUNC( SYSDATE ) - ADD_MONTHS( SYSDATE,-1 ) + 1

4.时间timestamp转字符串

SELECT
    TO_CHAR( TO_TIMESTAMP_TZ( '2024-05-02T10:36:33.000+08:00', 'YYYY-MM-DD"T"HH24:MI:SS.FF3TZH:TZM' ), 'YYYY-MM-DD HH24:MI:SS' ) AS my_timestamp_str 
FROM
    dual;

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值