Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/hibernate/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/jpa/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Hibernate 如何计算JPQL中的周年日期_Hibernate_Jpa_Jpql - Fatal编程技术网

Hibernate 如何计算JPQL中的周年日期

Hibernate 如何计算JPQL中的周年日期,hibernate,jpa,jpql,Hibernate,Jpa,Jpql,我用的是JPA2 我可以在下面的Ms Access中查询它 例如,要在两年内找到周年纪念日: SELECT DATEADD(year, 2, initialdate) AS Anniv 或了解自初始日期起已过去了多少年: SELECT DATEDIFF(year, initialdate, GETDATE()) AS YearsPassed 我在JPQL的DATEADD中找不到函数 有人能帮我在JPQL中获得类似的效果吗?Hibernate会话提供了一种方法,让您可以直接访问。然后,您可以创

我用的是JPA2

我可以在下面的Ms Access中查询它

例如,要在两年内找到周年纪念日:

SELECT DATEADD(year, 2, initialdate) AS Anniv
或了解自初始日期起已过去了多少年:

SELECT DATEDIFF(year, initialdate, GETDATE()) AS YearsPassed
我在JPQL的
DATEADD
中找不到函数


有人能帮我在JPQL中获得类似的效果吗?Hibernate会话提供了一种方法,让您可以直接访问。然后,您可以创建并使用来执行您的函数

以下是OracleDB函数示例:

session.doWork(new Work() {
  public void execute(Connection connection) throws SQLException {
    CallableStatement call = connection.prepareCall("{ ? = call MYSCHEMA.MYFUNC(?,?) }");
    call.registerOutParameter( 1, Types.INTEGER ); // or whatever it is
    call.setLong(2, id);
    call.setLong(3, transId);
    call.execute();
    int result = call.getInt(1); // propagate this back to enclosing class
  }
});

或者在程序逻辑中计算此值。

Datediff对于计算已过去的年份非常糟糕。JPQL支持的sql函数: