将Java SQL Date从yyyy-MM-dd转换为dd MMMM yyyy格式的最佳方法

时间:2010-07-05 10:17:32

标签: java date format

是否有一种直接的方式将Java SQL日期从格式yyyy-MM-dd转换为dd MMMM yyyy格式?

我可以将日期转换为字符串,然后对其进行操作,但我宁愿将其保留为Java SQL日期。在我需要这样做的时候,数据已经从MySQL数据库中读取,所以我不能在那里进行更改。

4 个答案:

答案 0 :(得分:10)

java.sql.Datejava.util.Date(其中java.sql.Date是子类)等对象没有自己的格式。您使用java.text.DateFormat对象以特定格式显示这些对象,而DateFormat(而不是Date本身)决定了格式。

例如:

Date date = ...;  // wherever you get this
DateFormat df = new SimpleDateFormat("dd MMMM yyyy");
String text = df.format(date);
System.out.println(text);

注意:在不使用Date对象的情况下打印DateFormat对象时,如下所示:

Date date = ...;
System.out.println(date);

然后它将使用某种默认格式进行格式化。但是,该默认格式不是您可以更改的Date对象的属性。

答案 1 :(得分:6)

如果是用于演示,您可以立即使用SimpleDateFormat:

package org.experiment;

import java.sql.Date;
import java.text.SimpleDateFormat;

public class Dates {
    private static SimpleDateFormat df = new SimpleDateFormat("MMMM yyyy");

    public static void main(String[] args){

        Date oneDate = new Date(new java.util.Date().getTime());
        System.out.println(df.format(oneDate));
    }

}

答案 2 :(得分:5)

目前尚不清楚“Java SQL Date”的含义。如果你的意思是java.sql.Date,那么它并不真正拥有字符串格式......它只是一个数字。要以特定方式将格式化为,请使用java.text.SimpleDateFormat

之类的内容

或者,将其转换为Joda Time DateTime; Joda Time是比内置API更好的日期和时间API。例如,SimpleDateFormat不是线程安全的。

(请注意,java.sql.Date的精确度高于普通java.util.Date,但看起来你不需要它。)

答案 3 :(得分:1)

TL;博士

myJavaSqlDate.toLocalDate()
             .format(
                 DateTimeFormatter.ofLocalizedDate ( FormatStyle.LONG )
                                  .withLocale ( Locale.UK )
             )
  

2017年5月11日

不要将日期时间值与其文本表示形式混淆

正如其他人所说,日期时间对象的没有格式。只有从对象生成或由对象解析的字符串才具有格式。但是这样的字符串总是与日期时间对象分开并且不同。

使用对象,而不是字符串

避免使用字符串与数据库之间传递日期时间值。对于日期时间值,请使用日期时间类来实例化日期时间对象。

JDBC的目的是调解数据库和Java之间的类型差异。

使用java.time

其他答案已经过时了,因为他们使用了麻烦的旧遗留日期时间类或古老的Joda-Time库。两者都被java.time类所取代。

如果您手头有java.sql.Date个对象,请通过调用添加到旧类的新方法java.time.LocalDate转换为toLocalDate

LocalDate ld = myJavaSqlDate.toLocalDate() ;

对于符合JDBC drivers及更高版本的JDBC 4.2,您可以直接使用java.time类型。

您似乎对仅限日期的值感兴趣。所以使用LocalDateLocalDate类表示没有时间且没有时区的仅限日期的值。

要以所需格式生成字符串,您可以指定自定义格式设置模式。但我建议让java.time自动本地化。

要进行本地化,请指定:

  • FormatStyle确定字符串的长度或缩写。
  • Locale确定(a)翻译日期名称,月份名称等的人类语言,以及(b)决定缩写,大写,标点符号,分隔符等问题的文化规范

示例...

LocalDate ld = LocalDate.now ( ZoneId.of ( "America/Montreal" ) );  // Today's date at this moment in that zone.
DateTimeFormatter f = DateTimeFormatter.ofLocalizedDate ( FormatStyle.LONG ).withLocale ( Locale.UK );
String output = ld.format ( f );
  

输出:2017年5月11日

关于java.time

java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.DateCalendar和& SimpleDateFormat

现在位于Joda-Timemaintenance mode项目建议迁移到java.time类。

要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310

从哪里获取java.time类?

ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如IntervalYearWeekYearQuartermore