今天舍友问我,JDBC中的stmt.setDate()怎么挺入当前时间,传入参数new java.util.Date()不行,传入 参数new java.sql.Date(),试了一会,还是不行。此时,才发觉,自从用了Hibernate,JPA之后,我连原始的东西都忘记了。这可是一个很可悲的问题,决定来一次小测试!
package test;
import java.sql.Timestamp;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
public class SQLDate {
public static void main(String[] args){
System.out.println(System.currentTimeMillis()); //结果:1244711626453
java.util.Date date1 = new java.util.Date();
System.out.println(date1.toString()); //结果: Thu Jun 11 16:27:57 CST 2009
//java.sql.Date extends java.util.Date
java.sql.Date date2 = new java.sql.Date(System.currentTimeMillis());
System.out.println(date2.toString()); //结果: 2009-06-11
java.sql.Date date3 = new java.sql.Date(date1.getTime());
System.out.println(date3.toString()); //结果:2009-06-11
//Timestamp extends java.util.Date
Timestamp stamp1 = new Timestamp(System.currentTimeMillis());
System.out.println(stamp1.toString()); //结果: 2009-06-11 16:27:57.75
Timestamp stamp2 = new Timestamp(date1.getTime());
System.out.println(stamp2.toString()); //结果:2009-06-11 16:52:56.171
//日期时间转换成格式化的字符串
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
//format(java.util.Date date), Timestamp是java.util.Date的子类
String timeStr = sdf.format(stamp1);
System.out.println(timeStr); //结果:2009/06/11 16:52:56
//SimpleDateFormat extends DateFormat,DateFormat是抽象类
DateFormat df = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
String timeStr2 = df.format(date1);
String timeStr3 = df.format(date2);
System.out.println(timeStr2); //结果
:2009/06/11 16:52:56
System.out.println(timeStr3); //结果: 2009/06/11 16:52:56
//字符串转化为日期时间
try {
//parse()中的参数必须与sdf中定义的格式一致,否则抛异常
java.util.Date date6 = sdf.parse("2009/12/10 5:12:02");
System.out.println(date6.toString()); //结果: Thu Dec 10 05:12:02 CST 2009
java.sql.Date date7 = new java.sql.Date(date6.getTime());
System.out.println(date7.toString()); //结果: 2009-12-10
//注意: sdf.parse()返回值是java.util.Date类型,不能转化成java.sql.Date类型
//java.sql.Date date8 = (java.sql.Date)sdf.parse("2009/12/10 5:12:02"); //不可行
Timestamp stamp9 = new Timestamp(date7.getTime());
System.out.println(stamp9.toString()); //结果: 2009-12-10 05:12:02.0
} catch (ParseException e) {
e.printStackTrace();
}
}
}
这样测试一下,那几个常用日期时间类和字符串与日期时间类的转换的用法,也就一目了然了。贴到博客上,下次再遗忘时,打开来看看,也就立即记起来了!
关键词标签:Java
相关阅读
热门文章 eclipse中如何设置字体大小_eclipse字体大小
人气排行 JS验证日期格式是否正确Java中3DES加密解密调用示例Java技术-J2EE开发日记-MyEclipse快捷键与插件大全用Java删除文件夹里的所有文件JavaScript基本语法-常量和变量C#中的空值的判断JAVA实现屏幕抓图 远程桌面控制100多个很有用的JavaScript函数以及基础写法汇总
查看所有0条评论>>