是否有一种直接的方式将Java SQL日期从格式yyyy-MM-dd转换为dd MMMM yyyy格式?
我可以将日期转换为字符串,然后对其进行操作,但我宁愿将其保留为Java SQL日期。在我需要这样做的时候,数据已经从MySQL数据库中读取,所以我不能在那里进行更改。
答案 0 :(得分:10)
java.sql.Date
和java.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)
myJavaSqlDate.toLocalDate()
.format(
DateTimeFormatter.ofLocalizedDate ( FormatStyle.LONG )
.withLocale ( Locale.UK )
)
2017年5月11日
正如其他人所说,日期时间对象的没有格式。只有从对象生成或由对象解析的字符串才具有格式。但是这样的字符串总是与日期时间对象分开并且不同。
避免使用字符串与数据库之间传递日期时间值。对于日期时间值,请使用日期时间类来实例化日期时间对象。
JDBC的目的是调解数据库和Java之间的类型差异。
其他答案已经过时了,因为他们使用了麻烦的旧遗留日期时间类或古老的Joda-Time库。两者都被java.time类所取代。
如果您手头有java.sql.Date
个对象,请通过调用添加到旧类的新方法java.time.LocalDate
转换为toLocalDate
。
LocalDate ld = myJavaSqlDate.toLocalDate() ;
对于符合JDBC drivers及更高版本的JDBC 4.2,您可以直接使用java.time类型。
您似乎对仅限日期的值感兴趣。所以使用LocalDate
。 LocalDate
类表示没有时间且没有时区的仅限日期的值。
PreparedStatement::setObject
ResultSet::getObject
要以所需格式生成字符串,您可以指定自定义格式设置模式。但我建议让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 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.Date
,Calendar
和& SimpleDateFormat
现在位于Joda-Time的maintenance mode项目建议迁移到java.time类。
要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310。
从哪里获取java.time类?
ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如Interval
,YearWeek
,YearQuarter
和more。