oracle日期格式转换问题

wwhui 2010-05-07 03:01:51
如何将ORACLE中的这种日期格式:2010-5-7 下午 12:00:00
转换成:2010-5-7 24:00:00

谢谢。
...全文
6796 18 打赏 收藏 转发到动态 举报
写回复
用AI写文章
18 条回复
切换为时间正序
请发表友善的回复…
发表回复
wuzhen8449397 2010-09-30
  • 打赏
  • 举报
回复
我也不知道为什么 我按照你们给出的方式设置 查出来的效果还是跟原来一样
是不是oracle10g 的问题?
wwhui 2010-05-07
  • 打赏
  • 举报
回复
感谢大家的解答,问题已解决。
谢谢。。
wwhui 2010-05-07
  • 打赏
  • 举报
回复
非常感谢楼上的各位慷慨解答,现在有个很奇怪的问题:
select to_char(sysdate,'yyyy:mm:dd hh24:mi:ss') from dual;
得出的结果是:2010:05:07 18:42:11
但是如果换成:to_char(begin_time,'yyyy:mm:dd hh24:mi:ss'),把sysdate换成类型为DATE的列,就转换不过来了,比如:如果begin_time的值是:2010-5-7 下午 12:00:00,
转换后就成了:2010:05:07 11:00:00
dingjun123 2010-05-07
  • 打赏
  • 举报
回复
oracle date类型有自己的存储方式,你转换也只能转换成字符串的显示方式,而没有改变date类型,
另外date类型的每个域是有限制的,比如小时是0-23,哪有24的啊,所有的日期都没有24的

DINGJUN123>select to_date('2010050623','yyyymmddhh24') from dual;

TO_DATE('20100
--------------
06-5月 -10

DINGJUN123>alter session set nls_date_format='yyyymmdd hh24:mi:ss';

会话已更改。

DINGJUN123>/

会话已更改。

DINGJUN123>select to_date('2010050623','yyyymmddhh24') from dual;

TO_DATE('20100506
-----------------
20100506 23:00:00

DINGJUN123>alter session set nls_date_format='yyyymmdd hh:mi:ss';

会话已更改。

DINGJUN123>select to_date('2010050623','yyyymmddhh24') from dual;

TO_DATE('20100506
-----------------
20100506 11:00:00

DINGJUN123>alter session set nls_date_format='yyyymmdd hh24:mi:ss,am';
ERROR:
ORA-01818: 'HH24' 不使用上下午指示符


DINGJUN123>alter session set nls_date_format='yyyymmdd hh:mi:ss,am';

会话已更改。

DINGJUN123>select to_date('2010050623','yyyymmddhh24') from dual;

TO_DATE('2010050623','
----------------------
20100506 11:00:00,下午


xiaofirehu 2010-05-07
  • 打赏
  • 举报
回复
SELECT TO_CHAR(SYSDATE, 'HH24:MI:SS') FROM DUAL;
17:40:18

SELECT TO_CHAR(SYSDATE, 'HH12:MI:SS') FROM DUAL;
05:40:18


至于 数据库到底存成什么格式的话并不影响使用吧
xieyu_zy 2010-05-07
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 adebayor 的回复:]
alter session set nls_date_format = 'yyyy-mm-dd hh24:mi:ss';
[/Quote]

[Quote=引用 2 楼 wwhui 的回复:]
非常感谢楼上。
按照楼上的操作了,但是显示的日期格式还是2010-5-7 下午 12:00:00。
[/Quote]

可以看下这个命令的适用范围,是修改当前SESSION,另外这不能修改第三方工具的日期格式,如:PL/SQL DEVELOPER需要在Tools->Preferences->User Interface->Date/Time下修改格式即可,第三方工具的日期格式在工具内部自己去设置,我估计你也应该在第三方工具下才会看到这样的效果,一般默认情况下ORACLE默认的日期格式不是这样的。

在默认的sqlplus或者sqlplusw下或者程序编写过程中,执行该命令后,如果是同一个session是肯定会产生你要的效果。

如果要将整体的数据库级别默认格式改掉需要修改参数文件,并重启数据库才可以,但是这个也改不掉你第三方工具的显示格式,第三方工具只能在工具内部去改,它只能改掉默认的日期格式,第三方工具都是转换后的;但是很多时候容易被工具所忽悠,给人的感觉就是数据库就是这样存储的,其实存储的只有日期格式,没有YYYYMM这些东西,这些东西都是通过算法计算出来的结果,然后根据格式要求进行对应的格式化给看到的这样的效果而已。
ojuju10 2010-05-07
  • 打赏
  • 举报
回复
select to_date(replace('2010-5-7 下午 11:00:00','下午',''),'YYYY-MM-DD HH24:MI:SS')
+(case when instr('2010-5-7 下午 11:00:00','下午')>0 then 12/24 else 0 end)
from dual
vbnsun 2010-05-07
  • 打赏
  • 举报
回复
sdfhisdfjsljdf
wwhui 2010-05-07
  • 打赏
  • 举报
回复
我的意思是把:2010-5-7 下午 11:00:00
转换成:2010-5-7 23:00:00

qwj8848 2010-05-07
  • 打赏
  • 举报
回复
如果你是用的SQLPLUS, 那么:
alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss'

如果你用的是PL /SQL DEVELOPER工具,那么:
TOOL --> PREFERENCE -->USER INTERFACE -->DATA/TIME 进行显示设置

xiaofirehu 2010-05-07
  • 打赏
  • 举报
回复
2010-5-7 下午 12:00:00。
不是
2010-5-7 24:00:00
没有 2010-5-7 24:00:00这个时间 只有 2010-5-8 00:00:00
xuelianlee 2010-05-07
  • 打赏
  • 举报
回复
alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss'
geniusqiao 2010-05-07
  • 打赏
  • 举报
回复
你的这个时间是怎么插成这样的?
是to_date('','YYYYMMDDHH24MISS')就这接变成这样了还是你的格式有什么特殊处理
心中的彩虹 2010-05-07
  • 打赏
  • 举报
回复

--下午12点 是不是晚上24点也就是零点
SQL> edi
已写入 file afiedt.buf

1 select to_char(to_date('2010-5-7 12:00:00','yyyy-mm-dd hh24:mi:ss')+interval '12' hour,
2* 'yyyy-mm-dd hh24:mi:ss') from dual
SQL> /

TO_CHAR(TO_DATE('20
-------------------
2010-05-08 00:00:00

ojuju10 2010-05-07
  • 打赏
  • 举报
回复
select to_date(datetime,'YYYY-MM-DD HH24:MI:SS','NLS_DATE_LANGUAGE = American') from tb
ojuju10 2010-05-07
  • 打赏
  • 举报
回复
转换比较麻烦
wwhui 2010-05-07
  • 打赏
  • 举报
回复
非常感谢楼上。
按照楼上的操作了,但是显示的日期格式还是2010-5-7 下午 12:00:00。
Adebayor 2010-05-07
  • 打赏
  • 举报
回复
alter session set nls_date_format = 'yyyy-mm-dd hh24:mi:ss';

17,377

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧