0

我有日期对象的格式

 /107/2013 12:00:00 AM

对我的期望值:

2013-07-01

我该怎么做?

我正在尝试使用此代码

public static  Date  formatearFecha( Date fecha ){

    String fechaString = new SimpleDateFormat("yyyy-MM-dd").format(fecha) ;
    DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
    Date fechaFormateada = null;
    try {
        fechaFormateada = df.parse(fechaString);
    } catch (ParseException ex) {
        Logger.getLogger(TestThings.class.getName()).log(Level.SEVERE, null, ex);
    }
    return fechaFormateada;

}

当我尝试进行测试时,我得到了这个:

 System.out.println( formatearFecha(myDate) );
 Mon Sep 30 00:00:00 COT 2013

更新:

我的问题是 sql 将 java.util.Date 更改为 java.sql.Date
我解决了这个问题:

private  String formatearFecha( Date fecha ){
    return new SimpleDateFormat("yyyy-MM-dd").format(fecha);
}

private java.sql.Date stringToSQLDate( String fecString ){

    java.sql.Date fecFormatoDate = null;
    try {
          SimpleDateFormat sdf = new java.text.SimpleDateFormat("yyyy-MM-dd", new Locale("es", "ES"));
         return  new java.sql.Date(sdf.parse(fecString).getTime());
    } catch (ParseException ex) { }
    return null;
}

并测试:

stringToSQLDate( formatearFecha( myDate ) );
4

2 回答 2

8

首先: java.util.Date 对象中从来没有存储格式。您可以将 Date 视为一个对象,该对象包含自 UTC 时区的纪元以来的毫秒长值。该类的方法很少,但没有存储时区偏移、格式化模式等。

其次,可以使用以下基本代码将日期格式化为机器语言环境中的 yyyy-MM-dd:

Date mydate = ...
DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
String mydateStr = df.format(mydate);

同样,您可以将字符串“/107/2013 12:00:00 AM”解析为机器语言环境中的日期对象,如下所示:

String mydateStr = "/107/2013 12:00:00 AM";
DateFormat df = new SimpleDateFormat("/dMM/yyyy HH:mm:ss aa");
Date mydate = df.parse(mydateStr);

上述两种方法可用于将格式化的日期字符串从一种更改为另一种。

有关格式化代码的更多信息,请参阅 SimpleDateFormat 的 javadoc 。

于 2013-09-05T05:05:19.313 回答
1
Date myDate = .......
DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
System.out.println(dateFormat.format(myDate));
于 2013-09-05T05:18:13.763 回答