涉及函数
to_date(char[fmt[,'nls_param’]]),to_char(date[,fmt,[,nls_param]])
1.1、to_date(char[fmt[,'nls_param’]]):将字符类型按一定格式转化为日期类型
具体用法:to_date('2004-11-27','yyyy-mm-dd'),前者为字符串,后者为转换日期格式,注意,前后两者要一一对应。
当时间为null时的用法:select to_date(null) from dual;
结果:1.2、to_char(date[,fmt,[,nls_param]]):将日期转按一定格式换成字符类型 ,fmt,nls_param为可选项,fmt指定了要转化的格式,nls_param指定了返回日期所使用的语言
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') time from dual;
结果:
1.3、求某天是星期几:
select to_char(to_date('2018-05-11','yyyy-mm-dd'),'DAY') from dual;
结果:
select to_char(to_date('2018-05-11','yyyy-mm-dd'),'DAY','NLS_DATE_LANGUAGE=American') from dual;结果:
1.4、设置日期语言:也就是设置nls_session_parameters视图的值
查看参数值:select * from nls_session_parameters where parameter = 'NLS_DATE_LANGUAGE';
修改时间以什么区域方式显示,比如是要显示MONDAY还是要显示星期一:alter session set NLS_DATE_LANGUAGE='American';日期格式: alter session set NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS';
多种日期格式:
YYYY:四位表示的年份
YYY,YY,Y:年份的最后三位、两位或一位,缺省为当前世纪
IYYY:ISO标准的四位年份
MM:01~12的月份编号
MON:缩写字符集表示
MONTH:全拼字符集表示的月份,右边用空格填补
Q:季度
W:当月第几周
WW:当年第几周
IW:ISO标准的年中的第几周
D:当周第几天
DD:当月第几天
DDD:当年第几天
DY:缩写字符集表示
DAY:全拼字符集表示的天 如(星期六)
HH,HH12:一天中的第几个小时,12进制表示法
HH24:一天中的第几个小时,取值为00~23
MI:一小时中的分钟
SS:一分钟中的秒
SSSS:从午夜开始过去的秒数
select to_char(sysdate, 'yyyy') 年,
to_char(sysdate, 'mm') 月,
to_char(sysdate, 'DD') 日,
to_char(sysdate, 'HH24') 时,
to_char(sysdate, 'MI') 分,
to_char(sysdate, 'SS') 秒,
to_char(sysdate, 'DAY') 天,
to_char(sysdate, 'Q') 第几季度,
to_char(sysdate, 'W') 当月第几周,
to_char(sysdate, 'WW') 当年第几周,
to_char(sysdate, 'D') 当周第几天,
to_char(sysdate, 'DDD') 当年第几天
from dual;
转载:https://blog.csdn.net/qq_33459369/article/details/80305175