Java、时间相关对象和oracle to_date函数

标签 java sql oracle jdbc to-date

我有一个 Oracle 数据库,其列名为 UPDATED在 sqlDeveloper 中标记为 TIMESTAMP(6) 。该列中的示例条目是 05-MAY-18 04.49.45.000000000

我想使用准备好的语句对其执行以下查询:

SELECT * FROM EXAMPLE_TABLE WHERE UPDATED > TO_DATE(?, 'YYYY-MM-DD HH24:MI:SS' .

问题是 - 如何绑定(bind) Java 日期时间对象(来自 org.joda.time.LocalDateTimejava.time.LocalDateTime 或任何其他同时保留数据和时间的对象?

这是一个测试片段,无论我做什么,我都无法使其工作(除了我绑定(bind) new Date(2018, 5,5) 的情况,但首先它只是没有时间的日期,其次 sql.Date 已过时。

public class Dbaccess {
    public static void main(String[] args) throws SQLException {
        Connection connection = DriverManager.getConnection("someurl", "some_username", "some_password");
        PreparedStatement preparedStatement = connection.prepareStatement("SELECT * FROM EXAMPLE WHERE UPDATED > TO_DATE(?, 'YYYY-MM-DD HH24:MI:SS')");
        preparedStatement.setObject(1, LocalDateTime.now());
        ResultSet resultSet = preparedStatement.executeQuery();
        System.out.println("resultSet:" + resultSet);
        while(resultSet.next()) {
            System.out.println(resultSet.getString("some_id"));
        }
    }
}

不幸的是,我得到 Exception in thread "main" java.sql.SQLException: Invalid column type

现在我们应该如何绑定(bind)这样代表日期时间的变量?

最佳答案

tl;博士

检查您的 JDBC 驱动程序支持哪个 JDBC 版本

在 JDBC 4.2 及更高版本中,您可以执行以下操作:

myPreparedStatement.setObject(
    … ,
    LocalDateTime.now()
)

在 JDBC 4.2 之前,请参阅 Answer by YCF_L .

JDBC 4.2

截至JDBC 4.2,您可以直接与数据库交换java.time对象。无需再次使用java.sql.Timestamp

LocalDateTime ldt = LocalDateTime.now() ;  // Better to pass explicitly your desired time zone rather than rely implicitly on the JVM’s current default.

使用 setObject 方法传递到您准备好的语句。

myPreparedStatement.setObject( … , ldt ) ;

检索。

LocalDateTime ldt = myResultSet.getObject( … , LocalDateTime.class ) ;

JDBC 4.1 及更早版本

如果您的JDBC driver尚未针对 JDBC 4.2 或更高版本进行更新,请参阅 the Answer by YCF_L


关于java.time

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 future 可能添加的内容的试验场。您可能会在这里找到一些有用的类,例如 Interval , YearWeek , YearQuarter ,和 more .

关于Java、时间相关对象和oracle to_date函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50217082/

相关文章:

java - 没有请求的Spring Boot运行 Controller

java - 在Java中准备动态Statement的正确方法

c# - SQL 代码比 C# 代码快吗?

mysql - 将选中的列表框插入数据库

java - 通过 BeanFactory.getBean(Class<T>) 检索通用 bean

java - 使用斯坦福 OpenIE 进行子句分割

mysql - MySQL 中的 CASE 性能?

java - 在 Spring 中使用 HikariCP 连接到 Oracle DB 时发送应用程序名称

php - 每 'X' 分钟从 Oracle 数据库查询并显示结果

oracle - 创建具有 rowid 属性的对象类型