Postgresql:到目前为止的整数

时间:2018-05-25 15:11:56

标签: postgresql date

我遇到将整数日期(20180525)转换为YYYY-MM-DD格式的日期的问题。有没有办法做到这一点,还是我应该在代码中转换它(在这种情况下是Java)?任何有关这方面的帮助将非常感激。谢谢!

2 个答案:

答案 0 :(得分:4)

如果您的日期存储为YYYYMMDD的整数,则可以先将其传递给日期函数,然后再转换为TEXT

SELECT date(20180525::TEXT)

否则,使用函数to_date和日期格式化程序:

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

答案 1 :(得分:2)

TL;博士

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年5月25日

java.time

关于问题中提到的Java,这里是使用现代 java.time 类的代码。是否应该使用SQL或Java来解析字符串取决于您的情况和您的品味,因为这两种方式都适用。

LocalDate

LocalDate类表示没有时间且没有时区的仅限日期的值。

您需要指定格式模式以匹配您的输入。在这种特殊情况下,输入字符串采用标准ISO 8601格式。具体而言,ISO 8601格式的“基本”变体可最大限度地减少分隔符的使用。在 java.time 中,您会找到this particular formatting pattern is conveniently predefined

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及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.DateCalendar和& SimpleDateFormat

现在位于Joda-Timemaintenance 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的试验场。您可以在此处找到一些有用的课程,例如IntervalYearWeekYearQuartermore