将整数转换为日期

55ooxyrt  于 2022-09-21  发布在  PostgreSQL
关注(0)|答案(3)|浏览(212)

我在将整数日期(20180525)转换为YYYY-MM-DD格式的日期时遇到问题。有没有办法做到这一点,或者我应该直接把它转换成代码(本例中是Java)?任何在这方面的帮助都将不胜感激。谢谢!

clj7thdc

clj7thdc1#

tl;DR

无论是SQL还是Java都运行得很好。关于SQL,请参阅Ali的correct Answer

对于Java,将LocalDate传递给PreparedStatement查询。

LocalDate.parse(                      // `LocalDate` represents a date-only value without time-of-day and without time zone. Works with SQL-standard `DATE` type.
    Integer.toString( 20180525 ) ,    // Convert integer to text, for a `String` object as input.
    DateTimeFormatter.BASIC_ISO_DATE  // Specify a formatting pattern to match our input string.
)                                     // Returns a `LocalDate` object.

2018-05-25

java.time

关于问题中提到的Java,以下是使用现代java.time类的代码。您应该使用SQL还是Java来解析您的字符串,这取决于您的情况和您的喜好,因为这两种方法都有效。

LocalDate

LocalDate类表示不带时间和时区的仅日期值。

您需要指定与您的输入匹配的格式模式。在这种情况下,您的输入字符串是标准的ISO 8601格式。具体地说,就是最大限度地减少分隔符使用的ISO 8601格式的“基本”变体。在java.time中,您会发现这个特定的格式化模式已经为您预先定义好了。

String input = Integer.toString( 20180525 ) ;  // Convert integer to text for input as `String`. 
DateTimeFormatter f = DateTimeFormatter.BASIC_ISO_DATE ;
LocalDate ld = LocalDate.parse( input , f ) ;

Ld.toString():2018-05-25

JDBC

JDBC 4.2及更高版本开始,您可以直接与数据库交换java.time对象。使用智能对象总是比使用愚蠢的字符串更好。

String sql = "SELECT event_date FROM tbl WHERE event_date = ? ; " ;
…
myPreparedStatement.setObject( 1 , ld ) ;

和取回。

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

关于java.time

java.time框架内置于Java 8及更高版本中。这些类取代了java.util.DateCalendarSimpleDateFormat等麻烦的旧legacy日期时间类。

Joda-Time项目现在位于maintenance mode中,建议迁移到java.time类。

要了解更多信息,请参阅Oracle Tutorial。和搜索堆栈溢出以获取许多示例和解释。规格为JSR 310

您可以直接与您的数据库交换java.time对象。使用符合JDBC 4.2或更高版本的JDBC driver。不需要字符串,不需要java.sql.*类。

从哪里可以获得java.time类?

  • Java SE 8**、Java SE 9Java SE 10及更高版本

  • 内置。

  • 带有捆绑实现的标准Java API的一部分。

  • Java 9添加了一些次要功能和修复。

  • Java SE 6Java SE 7**

  • ThreeTen-Backport中,许多java.time功能被重新移植到Java 6和7。

  • Android

  • 更高版本的Android捆绑实现的java.time类。

  • 对于更早版本的Android(<26),ThreeTenABP项目适配ThreeTen-Backport(如上所述)。参见How to use ThreeTenABP…

ThreeTen-Extra项目使用其他类扩展了java.time。该项目为将来可能添加到java.time中提供了一个试验场。您可以在这里找到一些有用的类,如IntervalYearWeekYearQuartermore

tcomlyy6

tcomlyy62#

select ((field_int)::text)::date as field_date from your_table;
inkz8wg9

inkz8wg93#

如果使用YYYYMMDD将日期存储为整数,则可以通过首先转换为TEXT将其传递给DATE函数。

SELECT date(20180525::TEXT)

否则,将函数TO_DATE与日期格式化程序一起使用:

SELECT to_date(20180525::text, 'YYYYMMDD')

相关问题