5

我正在尝试将以下字符串转换"2012-04-13 04:08:42.794"为日期类型:

    SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss.SSS");

    Date convertedDate;
    try {
        convertedDate = dateFormat.parse(dateString);
        System.out.println(" in utils: "+convertedDate.toString());
    } catch (ParseException e) {
        e.printStackTrace();
        return null;
    }


  //----------------- i think this is the problem
java.sql.Date sqlDate = new java.sql.Date(convertedDate.getTime());
        System.out.println("sql: "+sqlDate.toString());
        return sqlDate;

但这是打印以下内容:

in utils: Fri Apr 13 04:08:42 PDT 2012

如何获取此日期以保留毫秒?

4

5 回答 5

9

convertDate 对象实际上包含毫秒信息。这里的问题是 toString() 方法格式不打印毫秒。

 System.out.println(" in utils: " + dateFormat.format(convertedDate));

您还可以检查 ms 是否设置为

 System.out.println("millis: " + convertedDate.getTime());
于 2012-04-13T23:18:57.267 回答
1
 Calendar now = Calendar.getInstance();
 System.out.println("Current milliseconds since Jan 1, 1970 are :"
              + now.getTimeInMillis());

只需使用 java.util.Calendar http://docs.oracle.com/javase/7/docs/api/java/util/Calendar.html

于 2012-04-13T23:18:36.580 回答
1

他是我的目标(试图保持与你相同的代码风格):

import java.util.*;
import java.text.*;
public class main {
 public static void main(String[] args)throws Exception {
 long yourmilliseconds = 1119193190;
SimpleDateFormat sdf = new SimpleDateFormat("MMM dd,yyyy HH:mm:ss.SSS");

Date resultdate = new Date(yourmilliseconds);
System.out.println(sdf.format(resultdate));  } 
}  

输出 :

Jan 13,1970 17:53:13.190

问候, 厄瓦尔德

于 2012-04-13T23:19:23.147 回答
1

您可以制作自己的打印方法,而不是使用 toString() 打印,因此它会打印您特别想要的信息。另请注意,大多数 Date 类已被弃用 - 查看http://docs.oracle.com/javase/6/docs/api/java/util/Date.html

于 2012-04-13T23:21:25.113 回答
1
于 2018-02-25T21:32:41.673 回答