datetime、date、time、timestamp区别

1 篇文章 0 订阅

引用 https://www.cnblogs.com/andydao/p/3182146.html
我们看看这几个数据库中(mysql、oracle和sqlserver)如何表示时间
mysql数据库:它们分别是 date、datetime、time、timestamp和year。
date :“yyyy-mm-dd”格式表示的日期值
time :“hh:mm:ss”格式表示的时间值
datetime: “yyyy-mm-dd hh:mm:ss”格式
timestamp: “yyyymmddhhmmss”格式表示的时间戳值
year: “yyyy”格式的年份值。

date “1000-01-01”到“9999-12-31” 3字节
time “-838:59:59”到“838:59:59” 3字节
datetime “1000-01-01 00:00:00” 到“9999-12-31 23:59:59” 8字节
timestamp 19700101000000 到2037 年的某个时刻 4字节
year 1901 到2155 1字节
oracle数据库:
Date类型的内部编码为12
长度:占用7个字节
数据存储的每一位到第七位分别为:世纪,年,月,日,时,分,秒
TIMESTAMP是支持小数秒和时区的日期/时间类型。对秒的精确度更高
TIMESTAMP WITH TIME ZONE类型是TIMESTAMP的子类型,增加了时区支持,占用13字节的存储空间,最后两位用于保存时区信息
INTERVAL 用于表示一段时间或一个时间间隔的方法.在前面有多次提过.INTERVAL有两种类型.
YEAR TO MONTH 能存储年或月指定的一个时间段.
DATE TO SECOND存储天,小时,分钟,秒指定的时间段.
sql server:datetime和smalldatetime
datetime数据类型所占用的存储空间为8个字节,其中前4个字节用于存储1900年1月1日以前或以后的天数,数值分正负,正数表示在此日期之后的日期,负数表示在此日期之前的日期;后4个字节用于存储从此日零时起所指定的时间经过的毫秒数。
smalldatetime数据类型使用4个字节存储数据。其中前2个字节存储从基础日期1900年1月1日以来的天数,后两个字节存储此日零时起所指定的时间经过的分钟数。
smalldatetime数据类型与datetime数据类型相似,但其日期时间范围较小,从1900年1月1日到2079年6月6日。此数据类型精度较低,只能精确到分钟,其分钟个位为根据秒数四舍五入的值,即以30秒为界四舍五入。

Java提供了几种处理日期和时间的类:`Date`、`LocalDate`、`LocalTime`、`LocalDateTime`、`ZonedDateTime`等等。其中,`Date`类是旧版本的日期时间类,而其他类是Java 8引入的新日期时间API。 `Date`类表示特定的日期和时间,但它在处理日期和时间时存在一些问题,因此在新的Java日期时间API中被废弃。推荐使用`LocalDate`、`LocalTime`和`LocalDateTime`类来处理日期和时间。 `LocalDate`类表示一个没有时区信息的日期,包含年、月、日信息。 `LocalTime`类表示一个没有日期信息的时间,包含时、分、秒和毫秒信息。 `LocalDateTime`类表示一个包含日期和时间的对象。 另外,如果你需要处理带有时区的日期和时间,可以使用`ZonedDateTime`类。 关于时间戳(timestamp),在Java中可以使用`Instant`类来表示。`Instant`类代表从1970年1月1日开始计数的秒数或纳秒数。你可以使用该类来表示一个特定的时间点。 以下是一个示例代码,演示了如何在Java中处理日期和时间: ```java import java.time.LocalDate; import java.time.LocalTime; import java.time.LocalDateTime; import java.time.ZonedDateTime; import java.time.Instant; public class DateTimeExample { public static void main(String[] args) { // 获取当前日期 LocalDate currentDate = LocalDate.now(); System.out.println("Current Date: " + currentDate); // 获取当前时间 LocalTime currentTime = LocalTime.now(); System.out.println("Current Time: " + currentTime); // 获取当前日期和时间 LocalDateTime currentDateTime = LocalDateTime.now(); System.out.println("Current Date and Time: " + currentDateTime); // 获取带时区的日期和时间 ZonedDateTime zonedDateTime = ZonedDateTime.now(); System.out.println("Zoned Date and Time: " + zonedDateTime); // 获取当前时间戳 Instant timestamp = Instant.now(); System.out.println("Timestamp: " + timestamp);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值