Oracle时间日期计算--计算某一日期为一年中的第几周

select
to_char(sysdate-10,'yyyymmdd')||':iw:'||to_char(sysdate-10,'iw')||':ww:'||to_char(sysdate-10,'ww')||':w:'||to_char(sysdate-10,'w')||':D周:'||to_char(sysdate-10,'D') d1,
to_char(sysdate-09,'yyyymmdd')||':iw:'||to_char(sysdate-09,'iw')||':ww:'||to_char(sysdate-09,'ww')||':w:'||to_char(sysdate-09,'w')||':D周:'||to_char(sysdate-09,'D') d2,
to_char(sysdate-08,'yyyymmdd')||':iw:'||to_char(sysdate-08,'iw')||':ww:'||to_char(sysdate-08,'ww')||':w:'||to_char(sysdate-08,'w')||':D周:'||to_char(sysdate-08,'D') d3,
to_char(sysdate-07,'yyyymmdd')||':iw:'||to_char(sysdate-07,'iw')||':ww:'||to_char(sysdate-07,'ww')||':w:'||to_char(sysdate-07,'w')||':D周:'||to_char(sysdate-07,'D') d4,
to_char(sysdate-06,'yyyymmdd')||':iw:'||to_char(sysdate-06,'iw')||':ww:'||to_char(sysdate-06,'ww')||':w:'||to_char(sysdate-06,'w')||':D周:'||to_char(sysdate-06,'D') d5,
to_char(sysdate-05,'yyyymmdd')||':iw:'||to_char(sysdate-05,'iw')||':ww:'||to_char(sysdate-05,'ww')||':w:'||to_char(sysdate-05,'w')||':D周:'||to_char(sysdate-05,'D') d6,
to_char(sysdate-04,'yyyymmdd')||':iw:'||to_char(sysdate-04,'iw')||':ww:'||to_char(sysdate-04,'ww')||':w:'||to_char(sysdate-04,'w')||':D周:'||to_char(sysdate-04,'D') d7,
to_char(sysdate-03,'yyyymmdd')||':iw:'||to_char(sysdate-03,'iw')||':ww:'||to_char(sysdate-03,'ww')||':w:'||to_char(sysdate-03,'w')||':D周:'||to_char(sysdate-03,'D') d8,
to_char(sysdate-02,'yyyymmdd')||':iw:'||to_char(sysdate-02,'iw')||':ww:'||to_char(sysdate-02,'ww')||':w:'||to_char(sysdate-02,'w')||':D周:'||to_char(sysdate-02,'D') d9,
to_char(sysdate-01,'yyyymmdd')||':iw:'||to_char(sysdate-01,'iw')||':ww:'||to_char(sysdate-01,'ww')||':w:'||to_char(sysdate-01,'w')||':D周:'||to_char(sysdate-01,'D') d1,
to_char(sysdate-00,'yyyymmdd')||':iw:'||to_char(sysdate-00,'iw')||':ww:'||to_char(sysdate-00,'ww')||':w:'||to_char(sysdate-00,'w')||':D周:'||to_char(sysdate-00,'D') d2,
to_char(sysdate+01,'yyyymmdd')||':iw:'||to_char(sysdate+01,'iw')||':ww:'||to_char(sysdate+01,'ww')||':w:'||to_char(sysdate+01,'w')||':D周:'||to_char(sysdate+01,'D') d3,
to_char(sysdate+02,'yyyymmdd')||':iw:'||to_char(sysdate+02,'iw')||':ww:'||to_char(sysdate+02,'ww')||':w:'||to_char(sysdate+02,'w')||':D周:'||to_char(sysdate+02,'D') d4,
to_char(sysdate+03,'yyyymmdd')||':iw:'||to_char(sysdate+03,'iw')||':ww:'||to_char(sysdate+03,'ww')||':w:'||to_char(sysdate+03,'w')||':D周:'||to_char(sysdate+03,'D') d5,
to_char(sysdate+04,'yyyymmdd')||':iw:'||to_char(sysdate+04,'iw')||':ww:'||to_char(sysdate+04,'ww')||':w:'||to_char(sysdate+04,'w')||':D周:'||to_char(sysdate+04,'D') d6,
to_char(sysdate+05,'yyyymmdd')||':iw:'||to_char(sysdate+05,'iw')||':ww:'||to_char(sysdate+05,'ww')||':w:'||to_char(sysdate+05,'w')||':D周:'||to_char(sysdate+05,'D') d7,
to_char(sysdate+06,'yyyymmdd')||':iw:'||to_char(sysdate+06,'iw')||':ww:'||to_char(sysdate+06,'ww')||':w:'||to_char(sysdate+06,'w')||':D周:'||to_char(sysdate+06,'D') d8,
to_char(sysdate+07,'yyyymmdd')||':iw:'||to_char(sysdate+07,'iw')||':ww:'||to_char(sysdate+07,'ww')||':w:'||to_char(sysdate+07,'w')||':D周:'||to_char(sysdate+07,'D') d9,
to_char(sysdate+08,'yyyymmdd')||':iw:'||to_char(sysdate+08,'iw')||':ww:'||to_char(sysdate+08,'ww')||':w:'||to_char(sysdate+08,'w')||':D周:'||to_char(sysdate+08,'D') d1,
to_char(sysdate+09,'yyyymmdd')||':iw:'||to_char(sysdate+09,'iw')||':ww:'||to_char(sysdate+09,'ww')||':w:'||to_char(sysdate+09,'w')||':D周:'||to_char(sysdate+09,'D') d2,
to_char(sysdate+10,'yyyymmdd')||':iw:'||to_char(sysdate+10,'iw')||':ww:'||to_char(sysdate+10,'ww')||':w:'||to_char(sysdate+10,'w')||':D周:'||to_char(sysdate+10,'D') d3,
to_char(sysdate+11,'yyyymmdd')||':iw:'||to_char(sysdate+11,'iw')||':ww:'||to_char(sysdate+11,'ww')||':w:'||to_char(sysdate+11,'w')||':D周:'||to_char(sysdate+11,'D') d4,
to_char(sysdate+12,'yyyymmdd')||':iw:'||to_char(sysdate+12,'iw')||':ww:'||to_char(sysdate+12,'ww')||':w:'||to_char(sysdate+12,'w')||':D周:'||to_char(sysdate+12,'D') d5,
to_char(sysdate+13,'yyyymmdd')||':iw:'||to_char(sysdate+13,'iw')||':ww:'||to_char(sysdate+13,'ww')||':w:'||to_char(sysdate+13,'w')||':D周:'||to_char(sysdate+13,'D') d6,
to_char(sysdate+14,'yyyymmdd')||':iw:'||to_char(sysdate+14,'iw')||':ww:'||to_char(sysdate+14,'ww')||':w:'||to_char(sysdate+14,'w')||':D周:'||to_char(sysdate+14,'D') d7,
to_char(sysdate+15,'yyyymmdd')||':iw:'||to_char(sysdate+15,'iw')||':ww:'||to_char(sysdate+15,'ww')||':w:'||to_char(sysdate+15,'w')||':D周:'||to_char(sysdate+15,'D') d8
from dual;

20200317:iw:12:ww:11:w:3:D周:3
20200318:iw:12:ww:12:w:3:D周:4
20200319:iw:12:ww:12:w:3:D周:5
20200320:iw:12:ww:12:w:3:D周:6
20200321:iw:12:ww:12:w:3:D周:7
20200322:iw:12:ww:12:w:4:D周:1
20200323:iw:13:ww:12:w:4:D周:2
20200324:iw:13:ww:12:w:4:D周:3
20200325:iw:13:ww:13:w:4:D周:4
20200326:iw:13:ww:13:w:4:D周:5
20200327:iw:13:ww:13:w:4:D周:6
20200328:iw:13:ww:13:w:4:D周:7
20200329:iw:13:ww:13:w:5:D周:1
20200330:iw:14:ww:13:w:5:D周:2
20200331:iw:14:ww:13:w:5:D周:3
20200401:iw:14:ww:14:w:1:D周:4
20200402:iw:14:ww:14:w:1:D周:5
20200403:iw:14:ww:14:w:1:D周:6
20200404:iw:14:ww:14:w:1:D周:7
20200405:iw:14:ww:14:w:1:D周:1
20200406:iw:15:ww:14:w:1:D周:2
20200407:iw:15:ww:14:w:1:D周:3
20200408:iw:15:ww:15:w:2:D周:4
20200409:iw:15:ww:15:w:2:D周:5
20200410:iw:15:ww:15:w:2:D周:6
20200411:iw:15:ww:15:w:2:D周:7

select to_char(TO_DATE('20110101', 'YYYYMMDD'), 'yyyyiw') as week, --oracle求当年的第几周 #常用,但是有一个问题,比如20181231是周一,但是却计算结果为201801,即2018第一周内。
to_char(TO_DATE('20110101', 'YYYYMMDD'), 'yyyyww') as week2, --oracle求当年的第几周
to_char(TO_DATE('20110101', 'YYYYMMDD'), 'yyyy') as year, --oracle求第几年
to_char(TO_DATE('20110101', 'YYYYMMDD'), 'yyyymm') as month, --oracle求当年的第几月
to_char(TO_DATE('20110401', 'YYYYMMDD'), 'yyyyW') as quarter, -- oracle求当年的第几季度
to_char(TO_DATE('20110401', 'YYYYMMDD'), 'yyyyw') as quarter, -- oracle求当年的第几季度
to_char(TO_DATE('20110401', 'YYYYMMDD'), 'yyyyq') as quarter -- oracle求当年的第几季度
from dual;

我自己实现的脚本:
select

T31267.CREATED_DATE as F31265,

(select to_char(to_date(T31267.CREATED_DATE,'yyyy-mm-dd'),'yyyyiw') from dual) as week

from LEAP.HMDM_DM_DLR_CLUE T31267

总结:

select to_char(TO_DATE('20110101', 'YYYYMMDD'), 'yyyyiw') as week, --oracle求当年的第几周 #常用,但是有一个问题,比如20181231是周一,但是却计算结果为201801,即2018第一周内。
to_char(TO_DATE('20110101', 'YYYYMMDD'), 'yyyyww') as week2, --oracle求当年的第几周
to_char(TO_DATE('20110101', 'YYYYMMDD'), 'yyyy') as year, --oracle求第几年
to_char(TO_DATE('20110101', 'YYYYMMDD'), 'yyyymm') as month, --oracle求当年的第几月
to_char(TO_DATE('20110101', 'YYYYMMDD'), 'yyyyddd') as day, --oracle求当年的第几天
to_char(TO_DATE('20110401', 'YYYYMMDD'), 'yyyyq') as quarter -- oracle求当年的第几季度
from dual

ww Same day of the week as the first day of the year 按年度1月1日的第一天为每周第一天
iw Same day of the week as the first day of the ISO week, which is Monday 每周一
w Same day of the week as the first day of the month 按月份1日的第一天作为每周第一天
这3个参数均为取每周第一天,区别如下:

ww,按每年的1月1日为第一周第一天,1月8日为第二周第一天……依此类推。

2010-1-1为2010年第一周第一天,取第一周的第一天,仍然为2010-1-1
SQL> select trunc(date'2010-1-1','w') from dual;

TRUNC(DATE'2010-1-1','W')
-------------------------
2010-1-1

2010-1-6为2010年第一周第六天,取第一周的第一天,为2010-1-1
SQL> select trunc(date'2010-1-6','w') from dual;

TRUNC(DATE'2010-1-6','W')
-------------------------
2010-1-1

2010-1-9为2010年第二周第二天,取这一周的第一天,为2010-1-8
SQL> select trunc(date'2010-1-9','w') from dual;

TRUNC(DATE'2010-1-9','W')
-------------------------
2010-1-8

w与ww功能类似,不过它是按每月的1日为每周第一天,例如1日为当月第一周第一天,8日为第二周第一天……依此类推。
那也就是说,1月份的参数w与ww用trunc函数的结果应该是一致的。

2010-3-1为当月第一周第一天,因此结果为2010-3-1
SQL> select trunc(date'2010-3-1','w') from dual;

TRUNC(DATE'2010-3-1','W')
-------------------------
2010-3-1

2010-3-8为当月第二周第一天,第二周第一天为2010-3-8
SQL> select trunc(date'2010-3-8','w') from dual;

TRUNC(DATE'2010-3-8','W')
-------------------------
2010-3-8

2010-3-9为当月第二周第二天,2010-3-8为第二周第一天
SQL> select trunc(date'2010-3-9','w') from dual;

TRUNC(DATE'2010-3-9','W')
-------------------------
2010-3-8

iw,不受月份与年份的影响,直接取日期参数的周一。
SQL> select trunc(date'2010-3-9','iw') from dual;

TRUNC(DATE'2010-3-9','IW')
--------------------------
2010-3-8

参考:
TRUNC(number,num_digits)
Number 需要截尾取整的数字。
Num_digits 用于指定取整精度的数字。Num_digits 的默认值为 0。如果Num_digits为正数,则截取小数点后Num_digits位;如果为负数,则先保留整数部分,然后从个位开始向前数,并将遇到的数字都变为0。
TRUNC()函数在截取时不进行四舍五入,直接截取。

针对数字的案例,如:

select trunc(123.458) from dual --123

select trunc(123.458,0) from dual --123

select trunc(123.458,1) from dual --123.4

select trunc(123.458,-1) from dual --120

select trunc(123.458,-4) from dual --0

select trunc(123.458,4) from dual --123.458

select trunc(123) from dual --123

select trunc(123,1) from dual --123

select trunc(123,-1) from dual --120

针对日期的案例,如:

select trunc(sysdate) from dual --2017/6/13 返回当天的日期

select trunc(sysdate,'yyyy') from dual --2017/1/1 返回当年第一天.

select trunc(sysdate,'mm') from dual --2017/6/1 返回当月第一天.

select trunc(sysdate,'d') from dual --2017/6/11 返回当前星期的第一天(以周日为第一天).

select trunc(sysdate,'dd') from dual --2017/6/13 返回当前年月日

select trunc(sysdate,'hh') from dual --2017/6/13 13:00:00 返回当前小时

select trunc(sysdate,'mi') from dual --2017/6/13 13:06:00 返回当前分钟

其他优秀链接推荐:

https://www.2cto.com/database/201302/191827.html
https://www.oschina.net/question/44870_3710

分类: oracle

Oracle时间日期计算--计算某一日期为一年中的第几周的更多相关文章

  1. C#获取指定日期为一年中的第几周

    /// <summary> /// 获取指定日期,在为一年中为第几周 /// </summary> /// <param name="dt">指 ...

  2. C#指定日期为一年中的第几周

    /// <summary> /// 获取指定时间在为一年中为第几周 /// </summary> /// <param name="dt">指定 ...

  3. Oracle--计算某一日期为一年中的第几周

    我自己实现的脚本: select T31267.CREATED_DATE as F31265, (select to_char(to_date(T31267.CREATED_DATE,'yyyy-mm ...

  4. C#计算当前日期为一年中的第几周

    方法一: private   int   WeekOfYear(string   date) { DateTime   curDay   =   Convert.ToDateTime(date); i ...

  5. Java日期时间API系列21-----Jdk8中java.time包中的新的日期时间API类,xk-time时间转换,计算,格式化,解析的工具

    通过工作之余,对Java8中java.time包源码的不断学习,使用和总结,开发了xk-time,初步完成,欢迎试用和提出建议! xk-time xk-time is a datetime conve ...

  6. 【Oracle】Oracle时间日期格式

    to_date("要转换的字符串","转换的格式")   两个参数的格式必须匹配,否则会报错. 即按照第二个参数的格式解释第一个参数. to_char(日期,& ...

  7. ORACLE时间日期格式使用总结(参考网上资料汇总)

    Oracle时间日期操作 sysdate+(5/24/60/60) 在系统时间基础上延迟5秒 sysdate+5/24/60 在系统时间基础上延迟5分钟 sysdate+5/24 在系统时间基础上延迟 ...

  8. Oracle时间日期函数

    ORACLE日期时间函数大全 TO_DATE格式(以时间:2007-11-02   13:45:25为例)           Year:              yy two digits 两位年 ...

  9. 用Java计算某个日期100天后的日期

    用Java计算日期时间,首先考虑到时间类,Java中提供的和时间日期相关的类里,有一个Calendar类,可以获取某个时间日期. 计算某个日期100天后的日期,思路如下: 1.先设定时间,例如2017 ...

随机推荐

  1. Android中使用AsyncTask

    >##今天写作业用到了AnsyncTask,记录一下自己的使用情况 >###1.Android.os.AsyncTask类 >  1.AsyncTask类对线程间通讯进行了包装,我们 ...

  2. python爬虫-MongoDB安装配置

    MongoDB安装配置: 在安装配置MongoDB的过程中遇到了很多问题,现在重新梳理一遍安装流程.遇到的问题及其解决方法 系统版本:Windows 10 MongoDB版本:4.2.1 1.下载地址 ...

  3. 带你学习Javascript中的函数进阶(一)

    1. 函数的定义和调用 1.1 函数的定义方式 函数声明方式function关键字(命名函数) 函数表达式(匿名函数) new Function() var fn = new Function('参数 ...

  4. git指令-删除

    git指令-删除 添加一个新文件test.txt到Git并且提交: $ git add test.txt $ git commit -m "add test.txt" [maste ...

  5. Python 安全修改私有属性

    设置私有属性之后,如何修改私有属性 class Room: def __init__(self,name,length,width): self.__name = name self.__length ...

  6. python复制多层目录下的文件至其他盘符对应的目录中

    一.需求 app打包需要打入一些H5进去,以便更快的加载页面.这些H5文件是散落在各个文件夹中的[如下列所示],偶尔各个文件夹还需新增文件,每次新增一个文件,需要改动jenkins上job脚本,比较麻 ...

  7. 二叉堆的BuildHeap操作

    优先队列(二叉堆)BuildHeap操作 \(BuildHeap(H)\)操作把\(N\)个关键字作为输入并把它们放入空堆中.显然,这可以使用\(N\)个相继的\(Insert\)操作来完成.由于每个 ...

  8. SpringBoot整合Mybatis对单表的增、删、改、查操作

    一.目标 SpringBoot整合Mybatis对单表的增.删.改.查操作 二.开发工具及项目环境 IDE: IntelliJ IDEA 2019.3 SQL:Navicat for MySQL 三. ...

  9. safari坑之 video

    博客地址: https://www.seyana.life/post/19 本来是打算给博客左上角的gif做个优化, 把gif换成webm,以video的形式自动播放,能从180k降到50k, 现在浏 ...

  10. 05 JPAUtil工具类

    public final class JPAUtil { // JPA的实体管理器工厂:相当于Hibernate的SessionFactory private static EntityManager ...