我是靠谱客的博主 活泼戒指,最近开发中收集的这篇文章主要介绍java.sql.Date、java.sql.Time、java.sql.TimeStamp真的有区别吗?,觉得挺不错的,现在分享给大家,希望可以做个参考。
概述
java.sql.Date、java.sql.Time、java.sql.TimeStamp到底啥区别?我们一起打破砂锅问到底:
网上很多说java.sql.Date只记录日期、java.sql.Time只记录时分秒、java.sql.TimeStamp记录年月日时分秒纳秒。
为什么下面的代码(1)、(2)、(3)、(4)获取完时间,年月日时分秒纳秒等等都能取出来?
public static void main(String[] args) { //(1) java.util.Date time1 = new java.util.Date(); //(2) java.sql.Date time2 = new java.sql.Date(System.currentTimeMillis()); //(3) java.sql.Time time3 = new java.sql.Time(System.currentTimeMillis()); //(4) java.sql.Timestamp time = new java.sql.Timestamp(System.currentTimeMillis()); System.out.println(time); DateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss 今年第ww周 第DD天"); System.out.println("北京时间:" + sdf.format(time1) + "n"); System.out.println("北京时间:" + sdf.format(time2)+ "n"); System.out.println("北京时间:" + sdf.format(time3)+ "n"); System.out.println("北京时间:" + sdf.format(time)+ "n"); }
我今天捣鼓了一下,发现java.sql.Date和java.sql.Time,都是继承java.util.Date。 而new一个java.util.Date() 实际上都是取System.currentTimeMillis()。
网上说的不是很准确,java.sql.Date和java.sql.Time只是他们的toString()方法的格式控制不一样,而println(obj)恰恰就是调用的obj的toString()方法,
网上说的不是很准确,java.sql.Date和java.sql.Time只是他们的toString()方法的格式控制不一样,而println(obj)恰恰就是调用的obj的toString()方法,
所以说输出的日期格式会有 “java.sql.Date只记录日期、java.sql.Time只记录时分秒、java.sql.TimeStamp记录年月日时分秒纳秒”谬论。
sdf.format(time),用的是java.util.Date的 fastTime,fastTime也就是System.currentTimeMillis()取得的值, 所以 sdf.format(time) 打印出来是一模一样的。
转载于:https://www.cnblogs.com/airduce/p/7069491.html
最后
以上就是活泼戒指为你收集整理的java.sql.Date、java.sql.Time、java.sql.TimeStamp真的有区别吗?的全部内容,希望文章能够帮你解决java.sql.Date、java.sql.Time、java.sql.TimeStamp真的有区别吗?所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复