文档章节

关于String、date、Timestamp之间的相互转换问题

不打伞的小鱼
 不打伞的小鱼
发布于 2015/08/21 14:34
字数 825
阅读 78
收藏 9

    

一、String与Date(java.util.Date)互转

 

     1.1 String -> Date

 

  1. String dateStr = "2010/05/04 12:34:23";   

  2.         Date date = new Date();   

  3.         //注意format的格式要与日期String的格式相匹配   

  4.         DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   

  5.         try {   

  6.             date = sdf.parse(dateStr);   

  7.             System.out.println(date.toString());   

  8.         } catch (Exception e) {   

  9.             e.printStackTrace();   

  10.         }  

String dateStr = "2010/05/04 12:34:23";
		Date date = new Date();
		//注意format的格式要与日期String的格式相匹配
		DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
		try {
			date = sdf.parse(dateStr);
			System.out.println(date.toString());
		} catch (Exception e) {
			e.printStackTrace();
		}

 

 

  1.2 Date -> String

 

   日期向字符串转换,可以设置任意的转换格式format

  1. String dateStr = "";   

  2.         Date date = new Date();   

  3.         //format的格式可以任意   

  4.         DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   

  5.         DateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH/mm/ss");   

  6.         try {   

  7.             dateStr = sdf.format(date);   

  8.             System.out.println(dateStr);   

  9.             dateStr = sdf2.format(date);   

  10.             System.out.println(dateStr);   

  11.         } catch (Exception e) {   

  12.             e.printStackTrace();   

  13.         }  

String dateStr = "";
		Date date = new Date();
		//format的格式可以任意
		DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
		DateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH/mm/ss");
		try {
			dateStr = sdf.format(date);
			System.out.println(dateStr);
			dateStr = sdf2.format(date);
			System.out.println(dateStr);
		} catch (Exception e) {
			e.printStackTrace();
		}

 二、String与Timestamp互转

 

 

   2.1 String ->Timestamp

 

 

   使用Timestamp的valueOf()方法

  1. Timestamp ts = new Timestamp(System.currentTimeMillis());   

  2.         String tsStr = "2011-05-09 11:49:45";   

  3.         try {   

  4.             ts = Timestamp.valueOf(tsStr);   

  5.             System.out.println(ts);   

  6.         } catch (Exception e) {   

  7.             e.printStackTrace();   

  8.         }  

Timestamp ts = new Timestamp(System.currentTimeMillis());
		String tsStr = "2011-05-09 11:49:45";
		try {
			ts = Timestamp.valueOf(tsStr);
			System.out.println(ts);
		} catch (Exception e) {
			e.printStackTrace();
		}

   注:String的类型必须形如: yyyy-mm-dd hh:mm:ss[.f...] 这样的格式,中括号表示可选,否则报错!!!

    如果String为其他格式,可考虑重新解析下字符串,再重组~~

 

    2.2 Timestamp -> String

 

  使用Timestamp的toString()方法或者借用DateFormat

 

  1. Timestamp ts = new Timestamp(System.currentTimeMillis());   

  2.         String tsStr = "";   

  3.         DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   

  4.         try {   

  5.             //方法一   

  6.             tsStr = sdf.format(ts);   

  7.             System.out.println(tsStr);   

  8.             //方法二   

  9.             tsStr = ts.toString();   

  10.             System.out.println(tsStr);   

  11.         } catch (Exception e) {   

  12.             e.printStackTrace();   

  13.         }  

Timestamp ts = new Timestamp(System.currentTimeMillis());
		String tsStr = "";
		DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
		try {
			//方法一
			tsStr = sdf.format(ts);
			System.out.println(tsStr);
			//方法二
			tsStr = ts.toString();
			System.out.println(tsStr);
		} catch (Exception e) {
			e.printStackTrace();
		}

 很容易能够看出来,方法一的优势在于可以灵活的设置字符串的形式。

三、Date( java.util.Date )和Timestamp互转

 

  声明:查API可知,Date和Timesta是父子类关系

 

 

  3.1 Timestamp -> Date

 

 

  1. Timestamp ts = new Timestamp(System.currentTimeMillis());   

  2.         Date date = new Date();   

  3.         try {   

  4.             date = ts;   

  5.             System.out.println(date);   

  6.         } catch (Exception e) {   

  7.             e.printStackTrace();   

  8.         }  

Timestamp ts = new Timestamp(System.currentTimeMillis());
		Date date = new Date();
		try {
			date = ts;
			System.out.println(date);
		} catch (Exception e) {
			e.printStackTrace();
		}

 很简单,但是此刻date对象指向的实体却是一个Timestamp,即date拥有Date类的方法,但被覆盖的方法的执行实体在Timestamp中。

 

 

   3.2 Date -> Timestamp

 

   父类不能直接向子类转化,可借助中间的String~~~~

 

 

java.sql.Date 只存储日期数据不存储时间数据
// 会丢失时间数据
preparedStatement.setDate(1, new java.sql.Date(date.getTime()));
//可以这样来处理
preparedStatement.setTimestamp(1, new java.sql.Timestamp(new java.util.Date().getTime()));

//想要得到完整的数据,包括日期和时间,可以这样
java.util.Date d = resultSet.getTimestamp(1);
//这样处理更合适一些,可以避免一些潜在Timestamp 问题
java.util.Date d = new java.util.Date(resultSet.getTimestamp(1).getTime());
自己补的话
这样的话:
        往数据库存储的时候可以接收 java.util.Date类型 再用getTime()方法得到代表那个Date对象的long值,再以这个long值 构造一个Timestamp对象 存进数据库中。
       从存数据库里取的时候,可以先得到Timestamp用他的getTime()方法得到long值,再以这个long值构造一个java.util.Date对象,这样就可以对这个Date对象操作了。不如说 new SimpleTimeFormat("yyyyy-MM-dd HH:mm:ss").format()等等


© 著作权归作者所有

不打伞的小鱼
粉丝 69
博文 42
码字总数 24218
作品 0
深圳
程序员
私信 提问
String、Date和Timestamp的互转

String、Date和Timestamp的互转 String和Date的互转 关于String和Date的互转,在java8后会有不同。因为java8添加java.time包及子包,其中主要API是关于日期、时间、时刻和时间段及它们之间的...

mingmingcome
2018/08/21
0
0
hsqldb 日期

DATE类型用于存储日期('yyyy-mm-dd'),TIME类型用于存储时间 ('hh:mm:ss'),DATETIME或TIMESTAMP用于存储日期和时间。不能用错了。有些数据库TIME类型可以存DATE,但是 HSQLDB不行。 可以给D...

asdtiang
2010/02/22
1K
0
Java中Date及Timestamp时间相关内容【转】

JavaSQLDAO java.util.date java.sql.date java.sql.timestamp 整理一: 这里的一片文章,我个人认为讲解的很详细,有对 java.sql.Date的使用还有困惑的请看。 java.sql.Date 只存储日期数据...

houyiwujing
2012/03/07
1K
0
HIbernate基本映射数据类型

Hibernate的基本映射数据类型是Java基本类型与标准SQL类型相互转换的桥梁,通过Hibernate的基本映射数据类型可以非常方便地将数据从一种形式转换成另一种形式,完成高质量的ORM任务。 3种数据...

iborder
2016/11/10
47
0
Java中Date插入数据库的一些问题总结(二)

Java中Date插入数据库的一些问题总结(二) 关于java.sql.Date中插入/提取数据库中 Date类型的date值–带有时分秒的方法 ———————————–楼主温馨提示:以下内容可以忽略,直接从下...

萧沐垚
2016/12/16
377
0

没有更多内容

加载失败,请刷新页面

加载更多

mac下redis安装、设置、启动停止

常用命令说明 redis服务器:redis-server redis客户端:redis-cli redis性能测试工具:redis-benchmark AOF文件修复工具:redis-check-aof RDB文件修复工具:redis-check-rd redis设置临时密...

botkenni
7分钟前
3
0
好程序员web前端分享HTML5常见面试题集锦四

好程序员web前端分享HTML5常见面试题集锦四 1、为什么要初始化CSS样式? 答案:因为浏览器的兼容问题,不同浏览器对有些标签的默认值是不同的,如果没对CSS初始化往往会出现浏览器之间的页面...

好程序员官方
8分钟前
2
0
CDN的网络架构是什么?

CDN网络架构主要由两大部分,分为中心和边缘两部分,中心指CDN网管中心和DNS重定向解析中心,负责全局负载均衡,设备系统安装在管理中心机房,边缘主要指异地节点,CDN分发的载体,主要由Cac...

云漫网络Ruan
8分钟前
2
0
pandas入门07---可视化

01 入门 制作提供信息的可视化是数据分析的重要任务之一。首先介绍一下matplotlib库。 import matplotlib.pyplot as pltimport numpy as npdata = np.arange(10)print(data)plt.plot(da...

筠初
9分钟前
2
0
201_PyTorch中文教程:Torch与Numpy互操作

201_PyTorch中文教程:Torch与Numpy互操作 更多参考: https://morvanzhou.github.io/tutorials/ 油管频道:https://www.youtube.com/user/MorvanZhou 依赖软件包: torch numpy Torch的更多数......

openthings
10分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部