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.pswp.cn/news/388606.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/388606.shtml
英文地址,請注明出處:http://en.pswp.cn/news/388606.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

密碼機

樹狀數組1 #include<bits/stdc.h>2 using namespace std;3 int x,y,c[200005];4 char str[20];5 int inline read(){6 int x0,f1;7 char chgetchar();8 while(ch<0||ch>9)9 chgetchar(); 10 while(ch>0&&ch<9){ 11 …

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…

sql management studio 附加mdf文件出錯的解決辦法

將mdf文件所在文件夾的權限改為everyone.&#xff0c;完全控制即可。

oracle raise_application_error,RAISE_ APPLICATION_ ERROR--之異常處理

平時用來測試的異常處理我們都是通過dbms_output.put_line來輸出異常信息&#xff0c;但是在實際的應用中&#xff0c;需要把異常信息返回給調用的客戶端。其實 RAISE_APPLICATION_ERROR 是將應用程序專有的錯誤從服務器端轉達到客戶端應用程序(其他機器上的SQLPLUS或者其他前臺…

金融信息交換協議

隨著網絡的使用&#xff0c;目前所有大型的金融機構都已經實現了自動化和數字化。當中肯定少不了互聯網的加入&#xff0c;那么在這當中&#xff0c;我們主要介紹一下FIX協議。它是由國際FIX協會組織提供的一個開放式協議&#xff0c;目的是推動國際貿易電子化的進程&#xff0…

2018大數據學習路線從入門到精通

最近很多人問小編現在學習大數據這么多&#xff0c;他們都是如何學習的呢。很多初學者在萌生向大數據方向發展的想法之后&#xff0c;不免產生一些疑問&#xff0c;應該怎樣入門&#xff1f;應該學習哪些技術&#xff1f;學習路線又是什么&#xff1f;今天小編特意為大家整理了…

相似鄰里算法_紐約市-鄰里之戰

相似鄰里算法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…

一、面向對象

第一節&#xff1a;面向對象編程1.面向對象三大原則&#xff1a;封裝&#xff1a;就是把客觀事物封裝成抽象的類&#xff0c;并且類可以把自己的數據和方法只讓可信的類或者對象操作&#xff0c;對不可信的進行信息隱藏。繼承&#xff1a;繼承&#xff0c;指可以讓某個類型的對…

[poj 1364]King[差分約束詳解(續篇)][超級源點][SPFA][Bellman-Ford]

題意 有n個數的序列, 下標為[1.. N ], 限制條件為: 下標從 si 到 sini 的項求和 < 或 > ki. 一共有m個限制條件. 問是否存在滿足條件的序列. 思路 轉化為差分約束, 就是 即 Si 為第 i 項的前綴和, 特別的 So 為0. 轉化不等式(連續子段和變為前綴和之差 > < 變為 &g…

linux質控命令,Linux下microRNA質控-cutadapt安裝

如果Linux系統已安裝pip或conda&#xff0c;cutadapt的安裝相對簡便一些&#xff0c;示例如下&#xff1a;1.pip安裝pip install --user --upgrade cutadapt添加環境變量echo export PATH$PATH:/your path/cutadapt-1.10/bin >> ~/.bashrc2.conda安裝conda install -c b…

采用多播傳送FIX行情數據的推薦方案

理由FIX協議由一個會話層協議&#xff0c;一個應用層協議和一套域數據字典組成。后兩者不依賴于FIX會話。而且&#xff0c;由于FIX會話作為Point-to-point&#xff08;點-對-點&#xff09;通信&#xff0c;并不適合于發布/訂閱模式&#xff08;如為大量接收者提供市場數據&…

AJAX 異步加載技術

AJAX 異步 JavaScript 和 XML。 AJAX 是一種用于創建快速動態網頁的技術。 通過在后臺與服務器進行少量數據交換&#xff0c;AJAX 可以使網頁實現異步更新。這意味著可以在不重新加載整個網頁的情況下&#xff0c;對網頁的某部分進行更新。 傳統的網頁&#xff08;不使用 AJAX…

linux分辨率和用戶有關嗎,Linux系統在高分屏非正常分辨率顯示

問題描述&#xff1a;win10重裝為Ubuntu16.04&#xff0c;在1920x1080的顯示屏上&#xff0c;linux系統分辨率只有800x600xrandr # 查看當前顯示分辨率#輸出&#xff1a;[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年共同發起。這些企業把他們及他們的行業視為一個整體&#xff0c;認為能夠從對交易指示&#xff0c;交易指令及交易執行的高效電子數…

觀光公交

【問題描述】 風景迷人的小城 Y 市&#xff0c;擁有 n 個美麗的景點。由于慕名而來的游客越來越多&#xff0c;Y 市特意安排了一輛觀光公交車&#xff0c;為游客提供更便捷的交通服務。觀光公交車在第 0 分鐘出現在 1 號景點&#xff0c;隨后依次前往 2、3、4……n 號景點。從…

linux行命令測網速,Linux命令行測試網速的方法

最近給服務器調整了互聯網帶寬的限速策略&#xff0c;調到100M讓自己網站也爽一下。一般在windows上我喜歡用speedtest.net來測試&#xff0c;測速結果也被大家認可。在linux上speedtest.net提供了一個命令行工具speedtest-cli&#xff0c;用起來很方便&#xff0c;這里分享一下…

Delphi XE2獲取漢字拼音首字母

function CnPYIndex(const CnString: string): string;{ 返回中文的拼音首字母}const ChinaCode: array[0..25, 0..1] of Integer ((1601, 1636), (1637, 1832), (1833, 2077), (2078, 2273), (2274, 2301), (2302, 2432), (2433, 2593), (2594, 2786), (9999, 0000), …

圖像處理傅里葉變換圖像變化_傅里葉變換和圖像床單視圖。

圖像處理傅里葉變換圖像變化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…

HDUOJ 1062 TEXT REVERSE

#include<iostream> #include<stdlib.h> #include <iomanip> #include<stack> using namespace std;int main(){//次數int n 0;while (cin >> n) {//這里需要讀一個字符&#xff0c;需要消除換行符的影響getchar();while (n--) {char c;stack&l…