Oracle中TIMESTAMP的几种类型介绍与实例
TIMESTAMP的几种类型比较
TIMESTAMP
时间戳类型,与date的区别在于,date不能精确到毫秒,而timestamp可以精确到毫秒,毫秒的位数为0-9位,默认为6位。
SQL>selecttpfromtimestamp_test; TP -------------------------------------------------------------------------------- 01-3月-1609.22.33.000000上午
TIMESTAMPWITHTIMEZONE
TIMESTAMPWITHTIMEZONE与TIMESTAMP的区别在于,前者输出显示携带存入该时间值的数据库时区,后者输出不携带时区。
SQL>selecttp_tzfromtimestamp_test; TP_TZ -------------------------------------------------------------------------------- 01-3月-1609.22.33.000000上午+08:00
TIMESTAMPWITHLOCALTIMEZONE与TIMESTAMP的区别在于,前者的输出受时区影响,会跟着时区的变化而变化,而后者存入数据库后将不受时区影响。即前者以数据库本地时区保存数据,输出时将转换成客户端时区输出。
SQL>selecttp_l_tzfromtimestamp_test; TP_L_TZ -------------------------------------------------------------------------------- 01-3月-1609.22.33.000000上午
实战演练
#创建timestamp_test测试表 SQL>createtabletimestamp_test(dtdate,tptimestamp(6),tp_tztimestamp(6)withtimezone,tp_l_tztimestamp(6)withlocaltimezone); Tablecreated #在测试表中添加数据 SQL>insertintotimestamp_testvalues(sysdate,sysdate,sysdate,sysdate); 1rowinserted SQL>commit; Commitcomplete #查看数据库的时区和当前会话的时区 SQL>selectdbtimezone,sessiontimezonefromdual; DBTIMEZONESESSIONTIMEZONE ------------------------------------------------------------------------------------- +00:00+08:00 #查看当前时间 SQL>selectsysdatefromdual; SYSDATE ----------- 2016/3/19: #查看测试表的数据 SQL>select*fromtimestamp_test; DTTPTP_TZTP_L_TZ ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 2016/3/19:01-3月-1609.22.33.000000上午01-3月-1609.22.33.000000上午+08:0001-3月-1609.22.33.000000上午 #修改当前会话的时区 SQL>altersessionsettime_zone='+10:00'; Sessionaltered #查看当前会话时区修改后的测试表的数据 SQL>selectdbtimezone,sessiontimezonefromdual; DBTIMEZONESESSIONTIMEZONE ------------------------------------------------------------------------------------- +00:00+10:00 SQL>select*fromtimestamp_test; DTTPTP_TZTP_L_TZ ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 2016/3/19:01-3月-1609.22.33.000000上午01-3月-1609.22.33.000000上午+08:0001-3月-1611.22.33.000000上午 Oracle的备份与恢复
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。