我有一个名为data
的变量,它具有今天的格式:Thu May 24 13:14:41 BRT 2018
。然后我将其格式化为MySQL的日期类型格式,即yyyy-MM-dd
。这段代码就是这样做的:
String dataFormatada = new SimpleDateFormat("yyyy-MM-dd").format(data);
我想要做的是将其恢复为日期类型。我尝试了一些事情,但他们没有工作。主要的解决方案是按照另一个Stack Overflow's questioin中所描述的那样做,并且通过一点点模型,我得到了我想要的东西:
String target = "Thu Sep 28 20:29:30 JST 2000";
DateFormat df = new SimpleDateFormat("yyyy-MM-dd", Locale.ENGLISH);
Date result = df.parse(target);
System.out.println(result);
但是当我在尝试解析时遇到此错误时,它无法正常工作:
java.text.ParseException: Unparseable date: "Thu Sep 28 20:29:30 JST 2000"
所以我不能只重新格式化data
变量,我不能将dataFormatada
带回日期格式。如何将dataFormatada
带到格式为yyyy-MM-dd的日期类型?
答案 0 :(得分:2)
您的目标字符串格式为EEE MMM dd HH:mm:ss zzz yyyy
格式。因此,您需要使用EEE MMM dd HH:mm:ss zzz yyyy
作为模式而不是yyyy-MM-dd
。
String target = "Thu Sep 28 20:29:30 JST 2000";
DateFormat df = new SimpleDateFormat("EEE MMM dd HH:mm:ss zzz yyyy", Locale.ENGLISH);
Date result = df.parse(target);
System.out.println(result);
如果您想将Date对象转换为yyyy-MM-dd
,请使用以下代码。
DateFormat dfDateToStr = new SimpleDateFormat("yyyy-MM-dd", Locale.ENGLISH);
String formattedDate = dfDateToStr.format(result);
System.out.println("Formatted Date String : "+formattedDate);
答案 1 :(得分:2)
您需要两个格式化程序,一个用于将原始字符串解析为Date
对象,一个用于将其格式化为所需的字符串:
public static void main(String[] args) throws Exception {
String target = "Thu Sep 28 20:29:30 JST 2000";
DateFormat parser = new SimpleDateFormat("EEE MMM dd kk:mm:ss z yyyy", Locale.ENGLISH);
Date result = parser.parse(target);
System.out.println(result);
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
String dataFormatada = format.format(result);
}
答案 2 :(得分:1)
对于SQL标准DATE
列,请将java.time.LocalDate
类与JDBC 4.2或更高版本一起使用。
myPreparedStatement.setObject(
… ,
ZonedDateTime.parse( // Represent a moment in a particular time zone.
"Thu May 24 13:14:41 BRT 2018".replace( "BRT" , "Europe/London" ) ,
DateTimeFormatter.ofPattern( "EEE MMM d HH:mm:ss z uuuu" , Locale.UK )
)
.toLocalDate() // Extract a date-only value, without time-of-day and without time zone.
)
我有一个名为data的变量,今天的格式如下:Thu May 24 13:14:41 BRT 201
这是一种糟糕的格式。将日期时间值作为文本进行交换时,请仅使用标准ISO 8601格式。方便的是, java.time 类在解析/生成字符串时默认使用这些格式。
BST
= ?? (巴西标准时间,英国标准时间,......)以continent/region
的格式指定proper time zone name,例如America/Montreal
,Africa/Casablanca
或Pacific/Auckland
。切勿使用诸如BST
或IST
之类的3-4字母缩写,因为它们不是真正的时区,不是标准化的,甚至不是唯一的(!)。
ZonedDateTime
课程会尝试猜测预期的时区。但是你应该不依赖代码中的猜测。
String input = "Thu May 24 13:14:41 BRT 2018";
DateTimeFormatter f = DateTimeFormatter.ofPattern( "EEE MMM d HH:mm:ss z uuuu" , Locale.UK );
ZonedDateTime zdt = ZonedDateTime.parse( input , f );
2018-05-24T13:14:41-03:00 [美国/圣保罗]
看起来 java.time 在Brazil Standard Time
猜测你的意思是BST
。如果您指的是其他区域,例如英国时间,请用适当的时区名称替换BST
字符串。
指定Locale
以确定(a)翻译日期名称,月份名称等的人类语言,以及(b)文化规范决定缩写,大小写,标点符号,分隔符和这样
String input = "Thu May 24 13:14:41 BRT 2018".replace( "BRT" , "Europe/London" );
DateTimeFormatter f = DateTimeFormatter.ofPattern( "EEE MMM d HH:mm:ss z uuuu" , Locale.UK );
ZonedDateTime zdt = ZonedDateTime.parse( input , f );
2018-05-24T13:14:41 + 01:00 [欧洲/伦敦]
LocalDate
你显然只关心约会对象。因此,提取仅限日期的对象LocalDate
。
LocalDate ld = zdt.toLocalDate() ;
不要将日期时间值与数据库交换为文本。而是使用JDBC和对象。从JDBC 4.2及更高版本开始,您可以直接与数据库交换 java.time 对象。
myPreparedStatement.setObject( … , ld ) ;
检索。
LocalDate ld = myResultSet.getObject( … , LocalDate.class ) ;
java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.Date
,Calendar
和& SimpleDateFormat
现在位于Joda-Time的maintenance mode项目建议迁移到java.time类。
要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310。
您可以直接与数据库交换 java.time 对象。使用符合JDBC driver或更高版本的JDBC 4.2。不需要字符串,不需要java.sql.*
类。
从哪里获取java.time类?
ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如Interval
,YearWeek
,YearQuarter
和more。