oracle解析儒略日,利用to_char获取当前日期准确的周数!

总的来说周数的算法有两种:

算法一:iw算法,每周为星期一到星期日算一周,且每年的第一个星期一为第一周,就拿2014年来说,2014-01-01是星期三,但还是算为今年的第一周,可以简单的用sql函数获取当前的周数:

PgSQL

SQL> SELECT to_char(SYSDATE, 'iw'),sysdate from dual;

TO SYSDATE

-- ---------

02 07-JAN-14

1

2

3

4

5

SQL>SELECTto_char(SYSDATE,'iw'),sysdatefromdual;

TOSYSDATE

-- ---------

0207-JAN-14

可以看到2014-01-07是第二周,但是有一个地方需要注意,按照这样的算法,一年中要么是52周,或者53周,如果一年当中的第52周之后至当年的12月31日之前,还有大于或等于4天的话,那这几天就定为当年的第53周,如果不足4天,就将剩余的这些天数归为下一年的第一周,就拿今年举例,2013年30日和31日落单,不足4天,所以2013年只有52周,这2天定位2014年的第一周。

此外还有一个地方需要注意,比如2014-01-01是周三,2014年的第一个周一是2014-01-06,结果是第一个周一已经算是第二周了,这样程序处理起来可能比较麻烦,后面我们将会说明怎么处理。

算法二:ww算法,每年的1月1日作为当年的第一周的第一天,不管当年的1月1日是星期几,用sql表达就是

PgSQL

SQL> SELECT to_char(SYSDATE, 'ww'),sysdate from dual;

TO SYSDATE

-- ---------

01 07-JAN-14

1

2

3

4

5

SQL>SELECTto_char(SYSDATE,'ww'),sysdatefromdual;

TOSYSDATE

-- ---------

0107-JAN-14

可以看到这两种算法得出来的结果不一致,这种算法可能第一周和最后一周不足7天。但是算法简单。

通过如上两种算法,就可以得到日期的周数。

PgSQL

SQL> SELECT to_char(to_date('20140107', 'YYYY-MM-DD'),'iw') from dual;

TO

--

02

1

2

3

4

5

SQL>SELECTto_char(to_date('20140107','YYYY-MM-DD'),'iw')fromdual;

TO

--

02

另外附上用于日期和时间的Format:

FORMAT 描述

HH 一天的小时数 (01-12)

HH12 一天的小时数 (01-12)

HH24 一天的小时数 (00-23)

MI 分钟 (00-59)

SS 秒 (00-59)

MS 毫秒 (000-999)

US 微秒 (000000-999999)

SSSS 午夜后的秒 (0-86399)

AM 或 A.M. 或 PM 或 P.M. 正午标识(大写)

am 或 a.m. 或 pm 或 p.m. 正午标识(小写)

Y,YYY 带逗号的年(4 和更多位)

YYYY 年(4和更多位)

YYY 年的后三位

YY 年的后两位

Y 年的最后一位

IYYY ISO 年(4位或更多位)

IYY ISO 年的最后 3 位

IY ISO 年的最后 2 位

I ISO 年的最后一位

BC 或 B.C. 或 AD 或 A.D. 纪元标识(大写)

bc 或 b.c. 或 ad 或 a.d. 纪元标识(小写)

MONTH 全长大写月份名(空白填充为9字符)

Month 全长混合大小写月份名(空白填充为9字符)

month 全长小写月份名(空白填充为9字符)

MON 大写缩写月份名(3字符)

Mon 缩写混合大小写月份名(3字符)

mon 小写缩写月份名(3字符)

MM 月份号(01-12)

DAY 全长大写日期名(空白填充为9字符)

Day 全长混合大小写日期名(空白填充为9字符)

day 全长小写日期名(空白填充为9字符)

DY 缩写大写日期名(3字符)

Dy 缩写混合大小写日期名(3字符)

dy 缩写小写日期名(3字符)

DDD 一年里的日子(001-366)

DD 一个月里的日子(01-31)

D 一周里的日子(1-7;周日是1)

W 一个月里的周数(1-5)(第一周从该月第一天开始)

WW 一年里的周数(1-53)(第一周从该年的第一天开始)

IW ISO 一年里的周数(第一个星期四在第一周里)

CC 世纪(2 位)

J 儒略日(自公元前4712年1月1日来的天数)

Q 季度

RM 罗马数字的月份(I-XII;I=JAN)(大写)

rm 罗马数字的月份(I-XII;I=JAN)(小写)

TZ 时区名 (大写)

tz 时区名 (小写)

转载请注明: 版权所有,文章允许转载,但必须以链接方式注明源地址,否则追究法律责任!

最后编辑:2014-01-08作者:Jerry

61f384f23c24a3306817dc87a6906c2d.png

一个积极向上的小青年,热衷于分享--Focus on DB,BI,ETL

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/388606.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

js有默认参数的函数加参数_函数参数:默认,关键字和任意

js有默认参数的函数加参数PYTHON开发人员的提示 (TIPS FOR PYTHON DEVELOPERS) Think that you are writing a function that accepts multiple parameters, and there is often a common value for some of these parameters. For instance, you would like to be able to cal…

2018大数据学习路线从入门到精通

最近很多人问小编现在学习大数据这么多,他们都是如何学习的呢。很多初学者在萌生向大数据方向发展的想法之后,不免产生一些疑问,应该怎样入门?应该学习哪些技术?学习路线又是什么?今天小编特意为大家整理了…

相似邻里算法_纽约市-邻里之战

相似邻里算法IBM Data Science Capstone ProjectIBM Data Science Capstone项目 分析和可视化与服装店投资者的要求有关的纽约市结构 (Analyzing and visualizing the structure of New York City in relation to the requirements of a Clothing Store Investor) 介绍 (Introd…

linux质控命令,Linux下microRNA质控-cutadapt安装

如果Linux系统已安装pip或conda,cutadapt的安装相对简便一些,示例如下:1.pip安装pip install --user --upgrade cutadapt添加环境变量echo export PATH$PATH:/your path/cutadapt-1.10/bin >> ~/.bashrc2.conda安装conda install -c b…

linux分辨率和用户有关吗,Linux系统在高分屏非正常分辨率显示

问题描述:win10重装为Ubuntu16.04,在1920x1080的显示屏上,linux系统分辨率只有800x600xrandr # 查看当前显示分辨率#输出:[Screen 0: minimum 800 x 600, current 800 x 600, maximum 800 x 600]可以看出显示屏最小为800x600&…

数据透视表和数据交叉表_数据透视表的数据提取

数据透视表和数据交叉表Consider the data of healthcare drugs as provided in the excel sheet. The concept of pivot tables in python allows you to extract the significance from a large detailed dataset. A pivot table helps in tracking only the required inform…

金融信息交换协议(FIX)v5.0

1. 什么是FIXFinancial Information eXchange(FIX)金融信息交换协议的制定是由多个致力于提升其相互间交易流程效率的金融机构和经纪商于1992年共同发起。这些企业把他们及他们的行业视为一个整体,认为能够从对交易指示,交易指令及交易执行的高效电子数…

linux行命令测网速,Linux命令行测试网速的方法

最近给服务器调整了互联网带宽的限速策略,调到100M让自己网站也爽一下。一般在windows上我喜欢用speedtest.net来测试,测速结果也被大家认可。在linux上speedtest.net提供了一个命令行工具speedtest-cli,用起来很方便,这里分享一下…

图像处理傅里叶变换图像变化_傅里叶变换和图像床单视图。

图像处理傅里叶变换图像变化What do Fourier Transforms do? What do the Fourier modes represent? Why are Fourier Transforms notoriously popular for data compression? These are the questions this article aims to address using an interesting analogy to repre…

C#DNS域名解析工具(DnsLookup)

C#DNS域名解析工具(DnsLookup) DNS域名解析工具:DnsLookup 输入域名后点击Resolve按钮即可。 主要实现代码如下: private void btnResolve_Click ( object sender, EventArgs e ) {lstIPs.Items.Clear ( ); //首先把结果里的ListBox清空 try {IPHostE…

滞后分析rstudio_使用RStudio进行A / B测试分析

滞后分析rstudioThe purpose of this article is to provide some guide on how to conduct analysis of a sample scenario A/B test results using R, evaluate the results and draw conclusions based on the analysis.本文的目的是提供一些指南,说明如何使用R对…

Linux程序实现弹框,jQuery实现弹出框 效果绝对美观

使用到JQeury写的几个比较好的Popup DialogBox,觉得不错。和大家分享下。使用它们结合.net可以实现很好的效果。1.jqpopup:是个可以拖拽,缩放并可以在它上面显示html页面上任何一个控件组合的控件。可以和后面的主页面通信。使用方法:先调用这几个js文件,可以自提供的下载地址下…

MySQL的事务-原子性

MySQL的事务处理具有ACID的特性,即原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)。 1. 原子性指的是事务中所有操作都是原子性的,要…

大型网站架构演变

今天我们来谈谈一个网站一般是如何一步步来构建起系统架构的,虽然我们希望网站一开始就能有一个很好的架构,但马克思告诉我们事物是在发展中不断前进的,网站架构也是随着业务的扩大、用户的需求不断完善的,下面是一个网站架构逐步…

linux的磁盘磁头瓷片作用,Linux 磁盘管理

硬盘物理结构以下三张图片都是磁盘的实物图,一个磁盘是由多块堆放的瓷片组成的,所以磁头的结构也是堆叠的,他要对每一块瓷片进行读取,磁头是可以在不同磁道(在瓷片的表现为不同直径的同心圆,磁道间是有间隔的)之间移动…

多层插件开发框架

先来几张效果图: 1.基于DATASNAP构建的中间件,中间件已经经过实际项目的检验,单台中间件可支持几千客户端,中间件可集群 2.中间件支持同时连接ACCESS\SQL SERVER\MYSQL\ORACLE。。。多种数据库系统 3.中间件同时支持TCP/IP,HTTP&a…

unity3d 可视化编程_R编程系列:R中的3D可视化

unity3d 可视化编程In the last blog, we have learned how to create “Dynamic Maps Using ggplot2“. In this article, we will explore more into the 3D visualization in R programming language by using the plot3d package.在上一个博客中,我们学习了如何…

详谈P(查准率),R(查全率),F1值

怎么来的? 我们平时用的精度accuracy,也就是整体的正确率 acc predict_right_num / predict_num 这个虽然常用,但不能满足所有任务的需求。比如,因为香蕉太多了,也不能拨开人工的一个一个的看它的好坏(我爱吃啊&#…

网站系统分布式架构

写这篇文章之前,需要有些论点和论据,以表明网络系统在极端情况下的情况,先来看看世界上排名靠前的网站。 1、 FaceBook 2、 Google 从这两个站可以看出,当下比较极限的日均访问量在2~3亿,PV值…

python 数据科学 包_什么时候应该使用哪个Python数据科学软件包?

python 数据科学 包Python is the most popular language for data science. Unfortunately, it can be tricky to know which of the many data science libraries to use when. ☹️Python是数据科学中最流行的语言。 不幸的是,要知道何时使用许多数据科学库中的哪…