一、 常用日期数据格式

1.Y或YY或YYY 年的最后一位,两位或三位

SQL> Select to_char(sysdate,'Y') from dual;

TO_CHAR(SYSDATE,'Y')

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

7

SQL> Select to_char(sysdate,'YY') from dual;

TO_CHAR(SYSDATE,'YY')

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

07

SQL> Select to_char(sysdate,'YYY') from dual;

TO_CHAR(SYSDATE,'YYY')

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

007

2.Q 季度 1~3月为第一季度,2表示第二季度。

SQL> Select to_char(sysdate,'Q') from dual;

TO_CHAR(SYSDATE,'Q')

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

2

3.MM 月份数

SQL> Select to_char(sysdate,'MM') from dual;

TO_CHAR(SYSDATE,'MM')

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

05

4.RM 月份的罗马表示 (V在罗马数字中表示 5)

SQL> Select to_char(sysdate,'RM') from dual;

TO_CHAR(SYSDATE,'RM')

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

V

5.Month 用9个字符长度表示的月份名

SQL> Select to_char(sysdate,'Month') from dual;

TO_CHAR(SYSDATE,'MONTH')

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

5月

6.WW 当年第几周(2007年5月29日为2007年第22周)

SQL> Select to_char(sysdate,'WW') from dual;

TO_CHAR(SYSDATE,'WW')

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

22

7.W 本月第几周 (2007年5月29日为5月第5周)

SQL> Select to_char(sysdate,'W') from dual;

TO_CHAR(SYSDATE,'W')

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

5

8.DDD 当年第几天(2007年5月29日为2007年第149天)

SQL> Select to_char(sysdate,'DDD') from dual;

TO_CHAR(SYSDATE,'DDD')

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

149

9. DD 当月第几天

SQL> Select to_char(sysdate,'DD') from dual;

TO_CHAR(SYSDATE,'DD')

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

29

10.D 周内第几天

SQL> Select to_char(sysdate,'D') from dual;

TO_CHAR(SYSDATE,'D')

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

3

11.DY 中文的星期几 ((2007年5月29日为星期二))

SQL> Select to_char(sysdate,'DY') from dual;

TO_CHAR(SYSDATE,'DY')

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

星期二

12.HH或HH12 12进制小时数(16:09分为用12小时制计时为4点)

SQL> Select to_char(sysdate,'HH') from dual;

TO_CHAR(SYSDATE,'HH')

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

04

13.HH24 24小时制

SQL> Select to_char(sysdate,'HH24') from dual;

TO_CHAR(SYSDATE,'HH24')

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

16

二、常用时间函数

1.trunc(sysdate,'Q') 本季度第一天

SQL> select trunc(sysdate,'Q') from dual;

TRUNC(SYSDATE,'Q')

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

2007-4-1

2.trunc(sysdate,'D') 本周的第一天(周日)

SQL> select trunc(sysdate,'D')from dual;

TRUNC(SYSDATE,'D')

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

2007-5-27

3.last_day(sysdate) 本月最后一天

SQL> select last_day(sysdate) from dual;

LAST_DAY(SYSDATE)

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

2007-5-31 15:20:3

4.add_months(sysdate,2) 日期sysdate后推2个月

SQL> select add_months(sysdate,2) from dual;

ADD_MONTHS(SYSDATE,2)

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

2007-7-29 15:21:14

5.next_day(sysdate,2) 日期sysdate之后的第一周中,第2(指定星期的第几天)是什么日期

SQL> select next_day(sysdate,2) from dual;

NEXT_DAY(SYSDATE,2)

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

2007-6-4 15:22:10

6.Months_between(f,s) 日期f和s间相差月数

SQL> select

months_between(sysdate,to_date('2007-04-12','yyyy-mm-dd'))from

dual;

MONTHS_BETWEEN(SYSDATE,TO_DATE

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

1.56909908900836

7.得到SYSDATE+5所在的月份

SQL> SELECT

to_char(SYSDATE+5,'mon','nls_date_language=american') FROM

dual;

TO_CHAR(SYSDATE+5,'MON','NLS_D

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

jun

8.current_date()返回当前会话时区中的当前日期。

9.select dbtimezone from dual;

10.extract()找出日期或间隔值的字段值

SQL> select extract(month from sysdate) "This Month"

from dual;

This Month

----------

5

SQL> select extract(year from sysdate) "This year"

from dual;

This year

----------

2007

SQL> select extract(month from

add_months(sysdate,2)) " Month" from dual;

Month

----------

7

==================================================================

三、一些实践后的用法:

1.上月末天:

select to_char(add_months(last_day(sysdate),-1),'yyyy-MM-dd')

LastDay from dual;

2.上月今天

SQL> select

to_char(add_months(sysdate,-1),'yyyy-MM-dd') PreToday from

dual;

3.上月首天

SQL> select

to_char(add_months(last_day(sysdate)+1,-2),'yyyy-MM-dd') firstDay

from dual;

4.要找到某月中所有周五的具体日期

SELECT to_char(b.a,'YY-MM-DD')

FROM ( SELECT trunc(SYSDATE,'mm')+ROWNUM-1 a

FROM dba_objects where rownum < 32 ) b

WHERE to_char(b.a,'day')='星期五';

如果把where to_char(t.d, 'MM') = to_char(sysdate,

'MM')改成sysdate-90,即为查找当前月份的前三个月中

的每周五的日期。

5.得到系统当前月及以后的日期

select trunc(sysdate, 'MM')+ROWNUM-1 FROM dba_objects ;

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

to_date 字符串类型转为换日期类型

字符串中的相应位置上的字符,必须符合时间范围的限制

14.MI 分钟数(0~59)

提示注意不要将MM格式用于分钟(分钟应该使用MI)。MM是用于月份的格式,将它用于分钟也能工作,但结果是错误的。

15.SS 秒数(0~59)

总结:oracle时间操作用加减法就可以。基本单位为1天。20小时以后的时间应该怎样计算?

20小时要折算到分钟,就是1/1440,1小时就是1/24,20小时也可以用20/24或者1200/1400,120/144来表示,select

to_date( '2007-9-20  9:52:15

', 'yyyy-mm-dd  hh24:mi:ss ')+20/24

from  dual;这个就是加20小时了

oracle 本年1月1号 yy,ORACLE 日期函数相关推荐

  1. sql半小时,小时,天,月,年分组,日期函数day() 、month()、year()

    sql半小时,小时,天,月,年分组 每半小时 FLOOR( MINUTE ( stime ) / 30 ) * 30 )是按照 30 分钟分组 FLOOR( MINUTE ( stime ) / 10 ...

  2. 3月14号,oracle的说道多多

    今天算是被oracle给弄了一次,我们知道vs2005开发oracle的话装一个微软提供的小程序再加一个oracle client就可以了,今天算是让我彻底的记住了902这几个数字: 问题是这样的,在 ...

  3. Oracle查询一个月1-31号数据

    --模拟数据表create table [TB]([id] int,[time] datetime,[count] int)--添加模拟数据insert [TB]select 1,'2012-12-0 ...

  4. oracle建按月分区的表,ORACLE创建按月和按天的自动递增分区

    一.建按月自增分区表: 1.1建表 sql> create table month_interval_partition_table (id number,time_col date) part ...

  5. oracle 获取当月的1号_Oracle 获取当前年、月、日

    Oracle 获取当前年.月.日 1.//oracle中extract()函数从oracle 9i中引入,用于从一个date或者interval类型中截取到特定的部分  //语法如下  EXTRAC ...

  6. oracle 每个月求本年该月及之前的合计

    oracle 每个月求本年该月及之前的合计 问题具体描述:201901值为201901值,201902值为201901+201902,201903值为201901+201902+201903,以此类推 ...

  7. oracle 字符串 年月,oracle数据库dd-m月-yy字符串转为日期格式

    最近项目提出了个新需求,要根据k表的zfrq字段查询数据,而zfrq这个字段varchar2的日期格式是dd-m月-yy,例子:10-4月 -20或者10-11月-20,所以按日期查询的时候需要转换为 ...

  8. oracle数据库dd-m月-yy字符串转为日期格式

    最近项目提出了个新需求,要根据k表的zfrq字段查询数据,而zfrq这个字段varchar2的日期格式是dd-m月-yy,例子:10-4月 -20或者10-11月-20,所以按日期查询的时候需要转换为 ...

  9. oracle 日期加3个月,三个日期函数(十分有用)!!!!!!!!

    函数一: CREATE OR REPLACE FUNCTION dayadd( p_Component         varchar2, p_Number        number, p_Date ...

最新文章

  1. 《一个操作系统的实现》读书笔记连载ing……
  2. python基础语法教程:行与缩进
  3. mongodb幽灵操作的解决方案
  4. 火狐ok谷歌适配_“ OK Google”在锁定手机上的安全性越来越高
  5. 【A】兼容Core3.0后 Natasha 的隔离域与热编译操作。
  6. c语言汉字属于什么类型_空气悬浮风机在风机中属于什么类型?
  7. Debian 9 更换源 使用国内源 配置方法
  8. e分钟带你利用Python制作词云图
  9. 压缩html页面 seo,WordPress前端html代码压缩优化方法
  10. jQuery AJAX实现调用页面后台方法
  11. 2018美赛b题论文翻译
  12. 第一天mysq踩坑--ERROR 1820 (HY000): You must reset your password using ALTER USER statement before execut
  13. java 判断 string null_java 字符串为null 如何判断
  14. Source Insight——C/C++代码阅读器
  15. s905l android5,魔百盒M101晶晨S905L处理器专用安卓纯净刷机rom固件
  16. 网易游戏 Flink SQL 平台化实践
  17. git gitgitgitgitgit
  18. python isinstance得用法记录
  19. python nlp文本摘要实现_用TextRank算法实现自动文本摘要
  20. 用fock实现简易shell(程序替换)

热门文章

  1. oracle不能访问管理页面,Oracle Grid Control CONSOLE无法打开9i数据库的管理维护页面...
  2. 计算机基础知识复习资料,计算机基础知识复习资料
  3. 生物学专业_江南大学微生物学(发酵)20002008历年考研专业课真题汇编
  4. 如何用计算机算矩阵,【活用工具】教你如何用卡西欧fx82es计算机计算复数 矩阵...
  5. linux用java连接mysql_Java使用JDBC方式连接数据库
  6. python实现英文新闻摘要自动提取_Automotive Innovation摘要集系列2:Intelligent and Connected Vehicles...
  7. 电脑端二维码识别工具_电脑端自签工具更新,多功能软件一键签名
  8. php 谷歌翻译api_武汉武昌区地质勘测翻译公司-译嘉合翻译
  9. 本科计算机专业在车辆段,机电与轨道车辆工程系2021届毕业生参加成都铁路局车辆段及电务段认知实习...
  10. 在jsp中对mysql数据库分页的方法