【问题标题】:Java - Date timezone conversionJava - 日期时区转换
【发布时间】:2019-10-24 22:53:00
【问题描述】:

我正在尝试将 JSON 对象转换为日期并将其写入数据库。但是,将日期转换为 EST 的代码不起作用。将日期转换为 EST 的最佳方法是什么?

JSON 条目

"custom_date_1": "2019-05-19","

转换代码

int id;
Date trainingDate;

SimpleDateFormat format = new SimpleDateFormat("DD-MM-YY", Locale.US);
TimeZone tz = TimeZone.getTimeZone("EST");
format.setTimeZone(tz);

logger.info("custom_date_1: {}", object.getString("custom_date_1"));

 try {
      id= Integer.parseInt(object.getString("employee_number"));
      trainingDate = format.parse(object.getString("custom_date_1"));

      //Still says GMT
      logger.info("trainingDate: {}", trainingDate);

       map.put("employee_number", id);
       map.put("custom_date_1", trainingDate);
   } catch (ParseException e) {
       e.printStackTrace();
   }

日志声明

2019-06-10 14:00:00,226 INFO custom_date_1: 2019-05-19
2019-06-10 14:00:00,226 INFO trainingDate: Sun Dec 30 05:00:00 GMT 2018

【问题讨论】:

  • 当您有一个没有时间的日期时,在特定时区要求它有什么意义?
  • 任何日期都是特定时区中的同一日期。所以你可以用LocalDate.parse(date);把它转换成日期?
  • 当您说“EST”时,您的真正意思是“东部标准时间”(纽约冬季观察到的 UTC 偏移量),还是您的意思是“纽约时区”?如果是前者,则表示为UTC+5;如果是后者,表示为America/New_York。 (“EST”实际上是前者)。
  • 我建议你不要使用DateSimpleDateFormatTimeZone。那些课程设计糟糕且过时,尤其是中间的课程出了名的麻烦。而是使用来自java.time, the modern Java date and time APILocalDate(乍一看,在我看来你不需要任何其他类)。
  • @P.Soutzikevich 不,不是重复的。 That Question 是关于时间的日期,而这个问题似乎是关于仅日期的(虽然不清楚)。

标签: java date simpledateformat


【解决方案1】:

tl;博士

myPreparedStatement.setObject(       // In JDBC 4.2 and later, exchange *java.time* objects with your database. Use `PreparedStatement` to avoid SQL Injection attacks. 
    … ,                              // Specify which `?` placeholder to replace in your SQL statement. 
    LocalDate.parse( "2019-05-19" )  // Parse your standard ISO 8601 formatted input string as a date-only value represented in the `LocalDate` class. 
) 

详情

“custom_date_1”:“2019-05-19”,

您的输入字符串是标准的ISO 8601 格式。 java.time 类在解析/生成字符串时默认使用这些标准格式。所以不需要指定格式模式。

LocalDate ld = LocalDate.parse( "2019-05-19" ) ;

时区在这里无关紧要。所以你的问题很混乱。

我正在尝试将 JSON 对象转换为日期并将其写入数据库。

截至JDBC 4.2,我们可以与数据库交换java.time 对象。您在数据库中为这个仅日期值(没有时间和没有时区)的列应该是类似于标准 SQL 类型DATE 的类型。

myPreparedStatement.setObject( … , ld ) ;

检索。

LocalDate ld = myResultSet.getObject( … , LocalDate.class ) ;

【讨论】:

    【解决方案2】:

    从 Java 8 开始,您应该使用 LocalDateLocalDateTime,因此您可以使用进行时区转换

    LocalDateTime.atZone(ZoneId zoneId)

    例如

    LocalDateTime date = LocalDateTime.parse("2019-06-10T12:00:00"); 
    ZonedDateTime date2 = date.atZone(ZoneId.systemDefault());
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-12-01
      • 2020-03-08
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-01-17
      相关资源
      最近更新 更多