關于時間格式轉化:
java.util.Date 與 java.sql.Date 互換
sql是子類
字元串轉化成java.util.Date
SimpleDateFormat date =new SimpleDateFormat("yyyy-MM-dd");
String str="1992-5-6";
Date ud=date.parse(str);
java.util.Date 轉化成 java.sql.Date
String str = new SimpleDateFormat("yyyy-MM-dd").format(ud);
;
1、如何将java.util.Date轉化為java.sql.Date?
轉化:
java.sql.Date sd;
java.util.Date ud;
//initialize the ud such as ud = new ;
sd = new ;
2、如果要插入到資料庫并且相應的字段為Date類型
那麼可以用PreparedStatement.setDate(int ,方法
其中的java.sql.Date可以用上面的方法得到
PreparedStatement pst;
java.util.Date date=new ;
pst.setDate(1, ;//這裡的Date是sql中的::得到的是日期
pst.setTime(2, //sql包中的Time::得到的是時間
pst.setObject(3, ;//::得到的是日期及時間
也可以用資料庫提供TO_DATE函數
比如 現有 ud
TO_DATE(new SimpleDateFormat().format(ud,"yyyy-MM-dd HH:mm:ss"),
"YYYY-MM-DD HH24:MI:SS")
注意java中表示格式和資料庫提供的格式的不同
一個實際的例子
sql="update tablename set timer=to_date('"+t+"','yyyymmddhh24miss') where ....."
這裡的t為變量為類似:20151010131623
3、如何将"yyyy-mm-dd"格式的字元串轉換為java.sql.Date
方法1
SimpleDateFormat bartDateFormat =
new SimpleDateFormat("yyyy-MM-dd");
String dateStringToParse = "2017-7-12";
try {
java.util.Date date = bartDateFormat.parse(dateStringToParse);
java.sql.Date sqlDate = new ;
System.out.println(sqlDate.getTime());
}
catch (Exception ex) {
System.out.println(ex.getMessage());
}
------------------------------------------------------------
方法2
String strDate = "2017-08-09";
StringTokenizer st = new StringTokenizer(strDate, "-");
java.sql.Date date = new ,
Integer.parseInt(st.nextToken()),
Integer.parseInt(st.nextToken()));
【已忘記從何處摘來,親試完美,如有雷同莫怪!】