首 页
出境游
国内游
旅游指南
酒 店
飞 机
火 车
相 册
论 坛
旅游新闻
|
有问必答
|
票!票!全!
|
旅游曝黑台
|
旅行社交流
|
导游天地
|
说吧聊吧
|
时尚生活
|
爱心互助
当前位置:
首页
>
论坛
>
> 回复帖子
回复帖子
用户名
昵称
密 码:
主题标题:
选择话题
[原创]
[转贴]
[分享]
[景点]
[住宿]
[交通]
图 标:
[CODE]引用小青于2007/6/7 9:35:00说道: GMT和PST--关于时区的知识 1、概念和换算 2、日期中的时区标志 3、在Oracle 9i中正确转换时区 4、redhat9终端方式下更改时区 5、java下的时区...... GMT和PST--关于时区的知识 我们在网上浏览,在虚拟时空漫游世界时,经常会遇到时区的困扰,这篇文章是什么时间发布的?邮件是什么时间发出的?GMT和PST各代表什么意思,如何换算?等等. 我通过互联网搜集了一些小知识,供大家参考。 1、概念和换算 PST - 美国太平洋标准时间 GMT 格林威治标准时间 几个换算公式,因为是24进制,看起来有点怪: (GMT +8)-16 =PST PST+7 = GMT PST+16 = GMT + 8(中国) 我们是东八区,加州是西八区,中间差16个小时。 2、关于日期中的时区标志。 由于都在互联网上,大家在各个时区的事件表示有所不同,因此日期要转换到当前时区的日期和时间,在互联网上,大家一般都用CTS(世界标准时间)有称作GMT(格林尼治时间)。 譬如日期时间为:Sat, 30 Mar 2002 13:27:08 -0800,我们当前所在的时区为正8区(北京时间),则用我们所在时区表示就是 Sat, 30 Mar 2002 29(13+16):27:08 即Sun, 31 Mar 2002 6:27:08 +8000。 ---?? 目前存在的时区有: GMT 格林威治标准时间 GMT UTC 全球标准时间 GMT ECT 欧洲中部时间 GMT+1:00 EET 东欧时间 GMT+2:00 ART (阿拉伯)埃及标准时间 GMT+2:00 EAT 东非时间 GMT+3:00 MET 中东时间 GMT+3:30 NET 近东时间 GMT+4:00 PLT 巴基斯坦拉合尔时间 GMT+5:00 IST 印度标准时间 GMT+5:30 BST 孟加拉国标准时间 GMT+6:00 VST 越南标准时间 GMT+7:00 CTT 中国台湾时间 GMT+8:00 JST 日本标准时间 GMT+9:00 ACT 澳大利亚中部时间 GMT+9:30 AET 澳大利亚东部时间 GMT+10:00 SST 所罗门标准时间 GMT+11:00 NST 新西兰标准时间 GMT+12:00 MIT 中途岛时间 GMT-11:00 HST 夏威夷标准时间 GMT-10:00 AST 阿拉斯加标准时间 GMT-9:00 PST 太平洋标准时间 GMT-8:00 PNT 菲尼克斯标准时间 GMT-7:00 MST 西部山脉标准时间 GMT-7:00 CST 中部标准时间 GMT-6:00 EST 东部标准时间 GMT-5:00 IET 印第安那东部标准时间 GMT-5:00 PRT 波多黎各和美属维尔京群岛时间 GMT-4:00 CNT 加拿大纽芬兰时间 GMT-3:30 AGT 阿根廷标准时间 GMT-3:00 BET 巴西东部时间 GMT-3:00 CAT 中非时间 GMT-1:00 3、教你怎样在Oracle 9i中正确转换时区 在Oracle9i之前,虽然有一个NEW_TIME函数可以改变DATE的时间戳部分,但是还没有专门用来存储时区信息的数据类型。在Oracle9i 中,我们可以使用DBTIMEZONE伪字段查询数据库的时区,使用SESSIONTIMEZONE伪字段查询会话的时区。 但是,对于大多数数据库,这些值都是-07:00之类的偏移值,因此对于NEW_TIME函数是没有用的。Oracle9i有关NEW_TIME的文档建议使用FROM_TZ来替代,但是这可能会产生误导。FROM_TZ只将一个时区应用到一个时间戳上;它并不能把一个时区转换成另外一个时区。 其实有一个比较好的方法(从文档中得到这个方法可能有点难)。首先,为了完成这个工作,在正确的时区内需要一个TIMESTAMP WITH ZONE数据类型。然后,如果你将关键字AT TIME ZONE应用到那个值,它就会自动地调整为新的时区和日期。 select (timestamp '2003-04-06 01:59:59' at time zone 'PDT') at time zone 'GMT' from dual; 06-APR-03 08.59.59.00000000 AM GMT 这个语句将为太平洋白天时间(即其切换到PST之前的时刻)构造一个TIMESTAMP WITH TIME ZONE然后再将其转换到GMT。AT TIME ZONE关键字也接受默认的偏移值语法: select (timestamp '2003-04-06 02:00:00' at time zone '-07:00') at time zone '00:00' from dual; 06-APR-03 09.00.00.000000000 AM +00:00 你还可以使用伪字段来自动调整当前会话的时区: select current_timestamp at time zone dbtimezone from dual; 上面的表达式返回一个当前会话的本地时间(数据类型为时区),重新调整数据库的时区,调整后的时区将与SYSTIMESTAMP的结果相等。有了以上的这些信息,就可以构造一个比较好的NEW_TIME函数: create or replace function my_new_time (p_dwtz timestamp with time zone, p_tz varchar2 ) return date is begin return cast(p_dwtz at time zone p_tz as date); end my_new_time; / show errors; select my_new_time(sysdate,'+08:00') from dual; 即使第一个参数被标记为一个timestamp with time zone,你依然可以传入一个TIMESTAMP和DATE,这样由于Oracle的自动转型操作,得到的时间将是会话在本地时区的当前时间。这个函数接受包括偏移值在内的任何可以被TIMESTAMP识别的时区,然后将接受的时区调整为正确的值。[/CODE]
(最大4000个汉字) (Ctrl+Enter发表)
个人签名