对于公元前的日期 Oracle从 开始保存 公元前的年的保存的值和对应的公元后的年的值相加的和是 如上例中的公元 年和公元前 年的值相加 + = + =
SQL中DATE类型最后还包括一个 似乎目前没有使用
SQL>CREATE TABLE TEST_TIMESTAMP(TIME TIMESTAMP( ) TIME TIMESTAMP( ) WITH LOCAL TIME ZONE TIME TIMESTAMP( ) WITH TIME ZONE)
表已创建
SQL>INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP SYSTIMESTAMP SYSTIMESTAMP)
已创建 行
SQL>SELECT * FROM TEST_TIMESTAMP
TIME TIME TIME 月 下午 月 下午 月 下午 + :
SQL>SELECT DUMP(TIME ) DUMP(TIME ) DUMP(TIME ) FROM TEST_TIMESTAMP
DUMP(TIME ) DUMP(TIME ) DUMP(TIME ) Typ= Len= : b b fc c Typ= Len= : b b fc c Typ= Len= : b b fc c c c
可以发现 如果客户端和数据库中的时区是一致的 那么TIMESTAMP和TIMESTAMP WITH LOCAL TIME ZONE存储的数据是完全一样的
TIMESTAMP WITH TIME ZONE则略有不同 它保存的是 时区的时间 和所处的时区信息
修改客户端主机的时区 由东 区(+ 区)改为 时区
SQL>INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP SYSTIMESTAMP SYSTIMESTAMP)
已创建 行
修改客户端主机的时区 改为西 区( 时区)
SQL>INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP SYSTIMESTAMP SYSTIMESTAMP)
已创建 行
修改客户端主机的时区 改为西 区( 时区)
SQL>INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP SYSTIMESTAMP SYSTIMESTAMP)
已创建 行
修改客户端主机的时区 改为东 区(+ 时区)
SQL>INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP SYSTIMESTAMP SYSTIMESTAMP)
已创建 行
修改客户端主机的时区 改为西 区( 时区)
SQL>INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP SYSTIMESTAMP SYSTIMESTAMP)
已创建 行
修改客户端主机的时区 改为东 区(+ 时区)
SQL>INSERT INTO TEST_TIMESTAMP VALUES (SYSTIMESTAMP SYSTIMESTAMP SYSTIMESTAMP)
已创建 行
SQL>MIT
提交完成
修改客户端主机的时区 改回东 区(+ 时区)
SQL>SELECT * FROM TEST_TIMESTAMP
TIME TIME TIME 月 下午 月 下午 月 下午 + :
月 下午 月 下午 月 下午 + :
月 上午 月 下午 月 上午 :
月 上午 月 下午 月 上午 :
月 上午 月 下午 月 上午 + :
月 下午 月 上午 月 下午 :
月 上午 月 上午 月 上午 + :
已选择 行
SQL>SELECT DUMP(TIME ) DUMP(TIME ) DUMP(TIME ) FROM TEST_TIMESTAMP
DUMP(TIME ) DUMP(TIME ) DUMP(TIME ) Typ= Len= : b b fc c Typ= Len= : b b fc c Typ= Len= : b b fc c c c
Typ= Len= : b c c c e Typ= Len= : b c c c e Typ= Len= : b c c c e c
Typ= Len= : b b f a d c c Typ= Len= : b f a d c c Typ= Len= : b f a d c c f c
Typ= Len= : b b a f Typ= Len= : b b a f Typ= Len= : b b a f c
Typ= Len= : c f d Typ= Len= : b f d Typ= Len= : b f d c
Typ= Len= : b f cb bb c Typ= Len= : c e cb bb c Typ= Len= : b e cb bb c e
Typ= Len= : c b b Typ= Len= : c f b b Typ= Len= : b f b b d a
SQL>SELECT TO_NUMBER( C XXX ) TO_NUMBER( C XXX ) FROM DUAL
TO_NUMBER( C XXX ) TO_NUMBER( C XXX )
SQL>SELECT TO_NUMBER( XXX ) TO_NUMBER( C XXX ) TO_NUMBER( C XXXXXXX ) FROM DUAL
TO_NUMBER( XXX ) TO_NUMBER( C XXX )
SQL>SELECT TO_NUMBER( C XXX ) TO_NUMBER( E XXX ) TO_NUMBER( A XXX ) FROM DUAL
TO_NUMBER( C XXX ) TO_NUMBER( E XXX ) TO_NUMBER( A XXX )
可以看出 修改时区会导致系统TIMESTAMP时间发生变化 但是对于TIMESTAMP WITH LOCAL TIME ZONE类型 总是将系统的时间转化到数据库服务器上时区的时间进行存储
TIMESTAMP WITH TIME ZONE保存的是当前时间转化到 时区的对应的时间 并通过最后两位来保存时区信息
第一位表示时区的小时部分 时区用 x 表示 东n区在这个基础上加n 西n区在这个基础上减n 我们所处的东 区表示为 x C 西 区表示为 xF
lishixinzhi/Article/program/Oracle/201311/18690
oracle这样的日期‘01-8月 -50 08.00.00.000000000 上午 ’转为正常时间格式是1950,是设置错误造成的,解决方法如下:
1、打开oracle数据库新建一张表,话题是设置日期格式,因此字段2个date_time和time_time都是日期类型,如图。
2、这是简单的查询表,那是显示的日期还是日期格式,如图。
3、如果是现在查询的时候,查询日期显示结果设置日期格式,可以使用oracle数据库函数to_char来实现,这样的结果都是字符串,如图。
4、如果是在插入语句insert into 来把数据插入的表中,字符串的日期可以使用oracle数据库的函数to_date来实现把字符串转换成日期插入到数据库中,如图。
5、先修改日期类型,字符串的日期需要转换成日期格式,才能更新,这里也使用to_date函数。
6、如果执行删除语句,条件是日期,那么也可以使用oracle数据库to_date函数来实现。
7、这样就完成了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)