oracle 获得星期天为第一天,计算日期所在年的周

with tmp as (select

date '2016-12-31' d

from dual

)

select * from

(

select r, wn,

sum(decode(wn, 1, 1, 0))over(order by rownum) + decode(to_char(trunc(d, 'y') - 1, 'd'),1,1,1) nthweek

from (select trunc(d, 'y') + rownum - 1 r, d,

to_char(trunc(d, 'y') + rownum , 'd') - 1 wn

from tmp

connect by rownum <= d - trunc(d, 'y') + 1

)

) z

where z.r = date '2016-12-31'

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • ORACLE日期时间函数大全 TO_DATE格式(以时间:2007-11-02 13:45:25为例) Year:...
    雨一流阅读 730评论 0 2
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 34,856评论 18 399
  • 如何将小表放入keep池中? alter table xxx storage(buffer_pool keep);...
    一点也不想吃辣阅读 471评论 0 2
  • SQL ==SQLPLUS== DML(Data Manipulation Language,数据操作语言)---...
    蝌蚪1573阅读 639评论 0 4
  • 1.简介 数据存储有哪些方式?电子表格,纸质文件,数据库。 那么究竟什么是关系型数据库? 目前对数据库的分类主要是...
    乔震阅读 2,033评论 0 2

友情链接更多精彩内容