首页 > 数据库 >Oracle之TO_DATE函数

Oracle之TO_DATE函数

时间:2023-07-26 17:47:00浏览次数:41  
标签:12 date 函数 char DATE dual Oracle select

TO_DATE格式(以时间:2007-11-02 13:45:25为例)

Year:

yy two digits 两位年 显示值:07
yyy three digits 三位年 显示值:007
yyyy four digits 四位年 显示值:2007

Month:

mm number 两位月 显示值:11
mon abbreviated 字符集表示 显示值:11月,若是英文版,显示nov
month spelled out 字符集表示 显示值:11月,若是英文版,显示november

Day:

dd number 当月第几天 显示值:02
ddd number 当年第几天 显示值:02
dy abbreviated 当周第几天简写 显示值:星期五,若是英文版,显示fri
day spelled out 当周第几天全写 显示值:星期五,若是英文版,显示friday

Hour:

hh two digits 12小时进制 显示值:01
hh24 two digits 24小时进制 显示值:13

Minute:

mi two digits 60进制 显示值:45

Second:

ss two digits 60进制 显示值:25

其它

Q digit 季度 显示值:4
WW digit 当年第几周 显示值:44
W digit 当月第几周 显示值:1

24小时格式下时间范围为: 0:00:00 - 23:59:59
12小时格式下时间范围为: 1:00:00 - 12:59:59

1. 日期和字符转换函数用法(to_date,to_char)

select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') as nowTime from dual;   //日期转化为字符串  
select to_char(sysdate,'yyyy')  as nowYear   from dual;   //获取时间的年  
select to_char(sysdate,'mm')    as nowMonth  from dual;   //获取时间的月  
select to_char(sysdate,'dd')    as nowDay    from dual;   //获取时间的日  
select to_char(sysdate,'hh24')  as nowHour   from dual;   //获取时间的时  
select to_char(sysdate,'mi')    as nowMinute from dual;   //获取时间的分  
select to_char(sysdate,'ss')    as nowSecond from dual;   //获取时间的秒

2. 字符串和时间互转

select to_date('2004-05-07 13:23:44','yyyy-mm-dd hh24:mi:ss') from dual
select to_char( to_date(222,'J'),'Jsp') from dual //显示Two Hundred Twenty-Two    

3.求某天是星期几

select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day') from dual;     //星期一     
select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day',
'NLS_DATE_LANGUAGE = American') from dual;   // monday   

//设置日期语言     
ALTER SESSION SET NLS_DATE_LANGUAGE='AMERICAN';     

//也可以这样     
TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NLS_DATE_LANGUAGE = American')    

4. 两个日期间的天数

select floor(sysdate - to_date('20020405','yyyymmdd')) from dual;

5. 时间为null的用法

select id, active_date from table1     
UNION     
select 1, TO_DATE(null) from dual;  //注意要用TO_DATE(null)    

6.月份差

a_date between to_date('20011201','yyyymmdd') and to_date('20011231','yyyymmdd')     
//那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。     
//所以,当时间需要精确的时候,觉得to_char还是必要的

7. 日期格式冲突问题

输入的格式要看你安装的ORACLE字符集的类型, 比如: US7ASCII, date格式的类型就是: '01-Jan-01'

alter system set NLS_DATE_LANGUAGE = American     
alter session set NLS_DATE_LANGUAGE = American     

//或者在to_date中写     
select to_char(to_date('2002-08-26','yyyy-mm-dd'), 'day','NLS_DATE_LANGUAGE = American') from dual;     

//注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,可查看     
select * from nls_session_parameters     
select * from V$NLS_PARAMETERS    

8.查询特殊条件天数

select count(*)     
from ( select rownum-1 rnum     
   from all_objects     
   where rownum <= to_date('2002-02-28','yyyy-mm-dd') - to_date('2002-02-01','yyyy-mm-dd') + 1)     
where to_char( to_date('2002-02-01','yyyy-mm-dd')+rnum-1, 'D' )     
    not in ( '1', '7' )     
//查找2002-02-28至2002-02-01间除星期一和七的天数     
//在前后分别调用DBMS_UTILITY.GET_TIME, 让后将结果相减(得到的是1/100秒, 而不是毫秒).    

9. 查找月份

select months_between(to_date('01-31-1999','MM-DD-YYYY'), to_date('12-31-1998','MM-DD-YYYY')) "MONTHS" FROM DUAL;     
//结果为:1     

select months_between(to_date('02-01-1999','MM-DD-YYYY'), to_date('12-31-1998','MM-DD-YYYY')) "MONTHS" FROM DUAL;     
//结果为:1.03225806451613

10. Next_day的用法

Next_day(date, day)     
Monday-Sunday, for format code DAY     
Mon-Sun, for format code DY     
1-7, for format code D    

标签:12,date,函数,char,DATE,dual,Oracle,select
From: https://www.cnblogs.com/JaxYoun/p/17583127.html

相关文章

  • 【Oracle】 管道函数pipelined function简单的使用
    Oracle管道函数pipelinedfunction简单的使用如果在函数(function)中加关键字pipelined,就表明这是一个oracle管道函数,其返回值类型必为集合,体现出来的数据结构类似于表,即可以理解成,使用管道函数可以返回一张查询表,可以是单行数据也可以是多行数据,而不是平常函数返回的单行数据......
  • oracle查询相关性能语句
    ------------------------------SGA-----------------------------------------------SGA各部分大小showsgaselect*fromv$sga;SELECT*FROMV$SGAINFO;--SGA设置大小showparametersga_target--SGA各个池大小COLnameFORMATa32;SELECTpool,name,bytes/1024......
  • cache常用函数
    1.Set设置变量 sets=3 2.write输出变量 ws  3.kill 删除所有变量或一些指定的变量或所有变量除了指定的变量。 4.new 初始化变量。 5.Do(d):执行命令 6.Quit(q):结束执行一个函数并返回一个值 7.$Horolog$Horolog包含了时间和日期,它们由逗号分开。第一部分是......
  • oracle partition by 查询重复记录中的1条数据(获取表去重后的数据所有字段)
    1,partitionby分组后给分组数据排序selectt.*,row_number()over(partitionbyt."name",t."rid"orderbyt."rid")as"sort"from"person"t;2、获取去重后的记录selectt2.*from(SELECTt.*,row_number()over(partitionbyt.&......
  • Oracle日常性能问题查看 转载 https://www.cnblogs.com/yhq1314/p/10601630.html
    1判断回滚段竞争的sql--当Ratio大于2时存在回滚段竞争,需要增加更多的回滚段)selectrn.name,rs.GETS,rs.WAITS,(rs.WAITS/rs.GETS)*100ratiofromv$rollstatrs,v$rollnamernwherers.USN=rn.usn;2判断恢复日志竞争的sql,这句有问题不能使用--immediate_con......
  • ORACLE UNPIVOT函数
    语法     函数用途: UNPIVOT函数用来将列值转换为行值.1. INCLUDE|EXCLUDENULLS子句参数可以控制在结果集中是否保留值为NULL的行(新生成的行,即PIVOT_FOR_CLAUSE参数值)。当省略这个控制参数时,默认为EXCLUDENULLS,即去除空值行。2. 列转行后结果集中生成的......
  • 无涯教程-jQuery - bind( type, data, fn )方法函数
    bind(type,[data],fn)方法将处理程序绑定到每个匹配元素的一个或多个事件(如click)。也可以绑定自定义事件。bind(type,[data],fn)-语法selector.bind(type,[data],fn)这是此方法使用的所有参数的描述-type   - 一种或多种事件类型,以空格分隔。data  ......
  • Oracle数据完整性和锁机制
    Oracle数据完整性和锁机制本课内容属于Oracle高级课程范畴,内容略微偏向理论性,但是与数据库程序开发和管理、优化密切相关;另外本课的部分内容在前面章节已经涉及,请注意理论联系实际。事务  事务(Transaction)从通讯的角度看:是用户定义的数据库操作序列,这些操作要么全做、要么......
  • ORACLE函数大全
    ORACLE函数大全SQL中的单记录函数1.ASCII返回与指定的字符对应的十进制数;SQL>selectascii('A')A,ascii('a')a,ascii('0')zero,ascii('')spacefromdual;      A        A     ZERO    SPACE------------------------------------......
  • 15表达/生成式 内置函数
    三元表达式使用场景:二选一的时候推荐使用三元表达式#如果用户名是jason则打印管理员否则打印DSB(正常写的时候)username=input('username>>>:').strip()ifusername=='jason':print('管理员')else:print('DSB')"""不够简化"&quo......