java Date Timestamp 与MySQL datetime关系梳理

关于导包:

1 使用Date包为java.util.Date ,Date表示特定的瞬间,精确到毫秒。
Timestamp此类型由 java.util.Date 和单独的毫微秒值组成,包为java.sql.Timestamp。

数据库中是TIMESTAMP的,对应java的Timestamp,使用Date就会报错;

 

java.sql.Timestamp(时间戳)

继承父类:java.util.Date

所有已实现的接口:Serializable, Cloneable, Comparable<Date>

主要构造方法:Timestamp(long millis) 使用毫秒时间值构造 Timestamp 对象。

Timestamp允许 JDBC API 将该类标识为 SQL TIMESTAMP 值。它通过允许小数秒到纳秒级精度的规范来添加保存 SQLTIMESTAMP 小数秒值的能力。

Timestamp 也提供支持时间戳值的 JDBC 转义语法的格式化和解析操作的能力,主要用于写一些与数据库连接时的日期处理。

例如:

在 ResultSet中我们经常使用的setDate或getDate的数据类型是java.sql.Date,而在平时java程序中我们一般习惯使用 java.util.Date。

但是java.sql.Date 只存储日期数据不存储时间数据 ,这种符合规范的类型其实并没有把时分秒存进数据库,所以存取时就应该用Timestamp的setTimestamp()和

getTimestamp()。

整理一: String –> Timestamp:

Timestamp转换为String可以直接.toString(),但有时候显示时是不需要小数位后面的毫秒值,需要借助DateFormat在转换为String时重新定义格式。

使用Timestamp的valueOf()方法,

Timestamp time= new Timestamp(System.currentTimeMillis());//获取系统当前时间
SimpleDateFormat df = new SimpleDateFormat(“yyyy-MM-dd HH:mm:ss”);
String timeStr = df.format(time);
time = Timestamp.valueOf(timeStr);
System.out.println(time);//2017-05-06 15:54:21.0
整理二: java.util.Date –> Timestamp

方式1: 使用Timestamp的构造方法

Date date = new Date();
Timestamp ts = new Timestamp(date.getTime());
方式2:

注意:父类不能直接向子类转化,需要借助中间的String,并且format的格式要与Timestamp的字符串类型格式相匹配

java.lang.IllegalArgumentException: Timestamp format must be yyyy-mm-dd hh:mm:ss[.fffffffff]
Date date = new Date();
DateFormat sdf = new SimpleDateFormat(“yyyy-MM-dd HH:mm:ss”);
String dateStr = sdf.format(date);
Timestamp ts = Timestamp.valueOf(dateStr); //2017-05-06 15:54:21.0

整理三:
通过构造方法创建Timestamp 对象,获取毫秒值有下面三种方法:

方法1:

System.currentTimeMillis();

方法2:

Calendar.getInstance().getTimeInMillis();

方法3:

new Date().getTime();

测试证明:System.currentTimeMillis() 这种方式速度最快

Calendar.getInstance().getTimeInMillis() 这种方式速度最慢,因为Canlendar因为要处理时区问题会耗费很多的时间。

所以建议多使用第一种方式。

注意:Greenwich Mean Time 格林尼治标准时间

.Net产生的时间都是当前时区的当前时间,而Java的currentTimeMillis()方法得到的却是相对于GMT来的时间。

中国所在时区是+8区,故时间整整差了8小时!

 

方法摘要
boolean after(Timestamp ts)
指示此 Timestamp 对象是否晚于给定的 Timestamp 对象。
boolean before(Timestamp ts)
指示此 Timestamp 对象是否早于给定的 Timestamp 对象。
int compareTo(Date o)
将此 Timestamp 对象与给定的 Date(必须为 Timestamp 对象)相比较。
int compareTo(Timestamp ts)
将此 Timestamp 对象与给定 Timestamp 对象相比较。
boolean equals(Object ts)
测试此对象是否等于给定的 Timestamp 对象。
boolean equals(Timestamp ts)
测试此 Timestamp 对象是否等于给定的 Timestamp 对象。
int getNanos()
获取此 Timestamp 对象的 nanos 值。
long getTime()
返回此 Timestamp 对象表示的自 1970 年 1 月 1 日 00:00:00 GMT 以来的毫秒数。
void setNanos(int n)
将此 Timestamp 对象的 nanos 字段设置为给定值。
void setTime(long time)
设置此 Timestamp 对象,以表示 1970 年 1 月 1 日 00:00:00 GMT 以后 time 毫秒的时间点。
String toString()
使用 JDBC 时间戳转义格式编排时间戳。
static Timestamp valueOf(String s)
将使用 JDBC 时间戳转义格式的 String 对象转换为 Timestamp 值。
实例代码:

tLotteryAnnouncement.setDateTime(new Timestamp(System.currentTimeMillis()));
if(StringUtils.isNotBlank(tIsusesKj.getOpenTime())){
tLotteryAnnouncement.setOpenTime(Timestamp.valueOf(tIsusesKj.getOpenTime()));
}else{
tLotteryAnnouncement.setOpenTime(new Timestamp(tIsusesKj.getModifyDate().getTime()));
}

 

转换:

Date转Timestamp
一句搞定:

Timestamp createTime = new Timestamp(new Date().getTime());
1
Timestamp转Date
Timestamp t = new Timestamp(System.currentTimeMillis());
Date d = new Date(t.getTime());
————————————————
版权声明:本文为CSDN博主「TRX1024」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_43161811/article/details/88672414

mybatis于Date和DateTime现场插入
最近,该公司使用MyBatis3做数据持久层,有在该领域Date和DateTime种类,只有在插入数据时属性设置为一个实体Timestamp将相应mysql的DateTime类型。Date会相应mysql的Date类型。

在MyBatis映射文件里要表明映射类型。

<result column=”modified_date” jdbcType=”TIMESTAMP” property=”modified_date” javaType=”java.sql.Timestamp” />
<result column=”date” jdbcType=”DATE” property=”date” javaType=”java.util.Date” />
<result column=”date” jdbcType=”TIMESTAMP” property=”date” javaType=”java.util.Date” />

在使用字段的时候也要标明类型#{modified_date,jdbcType=TIMESTAMP}、#{date,jdbcType=DATE}。

 

MySQL datetime数据类型与Java数据类型对应关系:
MySQL : datetime 对应 jave: java.sql.TimeStamp。

赞赏

微信赞赏支付宝赞赏

编程知识分享网,一个有趣的平台!
编程知识分享网|编程教程|资源下载|源码下载 » java Date Timestamp 与MySQL datetime关系梳理

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
提示下载完但解压或打开不了?
最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
找不到素材资源介绍文章里的示例图片?
对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
关于编程知识分享网(www.ittce.com)
编程知识分享网,一个有趣的平台,小心有毒!

发表评论

  • 23会员总数(位)
  • 180资源总数(个)
  • 0本周发布(个)
  • 0 今日发布(个)
  • 1308稳定运行(天)

提供最优质的资源集合

立即查看 了解详情
升级SVIP尊享更多特权立即升级