【基础】关于Java向数据库中插入DateTime类型数据

时间:2021-04-04 00:40:46

2012年12月16日

前提:数据库中字段类型是:datetime

插入这种类型的数据,有两种方式。在外部可以有java.util.Date类与java.sql.Date类。

详细如下:


1.采用java.util.Date类  

SimpleDateFormat fm=new SimpleDateFormat("yyyy/MM/dd");   

Date date=new Date();

String dateStr=fm.format(date);   

转换为时间格式的字符串类型,再以字符串形式插入

pstmt.setString(dateStr) ;


2.采用java.sql.Date类

java.lang.Object 
继承者 java.util.Date 
继承者 java.sql.Date 

public class Dateextends Date 

public Date(int year, int month, int day) 
year - year 减去 1900,它必须是 0 到 8099 之间的数。(注意,8099 是由 9999 减去 1900 得到的。) 
month - 0 到 11 之间的数 
day - 1 到 31 之间的数 

一个包装了毫秒值的瘦包装器 (thin wrapper),它允许 JDBC 将毫秒值标识为 SQL DATE 值。毫秒值表示自 1970 年 1 月 1 日 00:00:00 GMT 以来经过的毫秒数。 

为了与 SQL DATE 的定义一致,由 java.sql.Date 实例包装的毫秒值必须通过将小时、分钟、秒和毫秒设置为与该实例相关的特定时区中的零来“规范化”。 

如果你要向数据库写入日期2001-12-12,需要Date date=new Date(2001-1900,11,12); 

再进行插入操作。即可。