java - 更新到 3.6.5 后,Hibernate 将属性映射到 SQL 公式失败

标签 java mysql hibernate

我刚刚从 3.3.0.GA 更新到 Hibernate 3.6.5.Final,在 XML 映射属性上调用 SQL 公式时遇到了问题:

<property
    name="endDate"
    type="java.util.Date"
    formula="TIMESTAMPADD(SECOND, (quantity*60*60), transactionDate)" 
/>

我没有更改 *.xml.hbm 中的任何内容,也没有更改数据库设计。之前我的 endDate 计算得很好,我现在得到一个 MySQLSyntaxErrorException:

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'this_.SECOND,(this_.quantity*60*60),this_.transactionDate) as formula0_0_ from t' at line 1

问题很明显,因为 this_.SECOND 应该是 SECOND。在我看来,Hibernate 将 TIMESTAMPADD 识别为公式,但不将 SECOND 识别为静态传递参数,因此认为它必须是表中的一列。我不确定如何告诉 hibernate 它应该按原样使用 SECOND

我已经在我的 Dialect 上尝试了 registerFunctionregisterKeyword 但没有任何运气,因为它们似乎与 HQL 函数定义相关,而不是公式中使用的 native SQL .

谁能给我指出正确的方向,或者告诉我 Hibernate 在这些版本之间有什么不同以及我该如何解决它?

最佳答案

我刚刚升级到 Hibernate 4.1.2,同样的问题又开始出现了。 [SECOND] 的解决方案不再有效,我不得不在我自己的自定义方言中注册关键字。喜欢:

public class ExtendedMySQL5InnoDBDialect extends MySQL5InnoDBDialect {

    public ExtendedMySQL5InnoDBDialect() {
        super();
        //make sure to register it in lowercase as uppercase does not work (took me 4 hours to realize)
        registerKeyword("second");

    }
}

关于java - 更新到 3.6.5 后,Hibernate 将属性映射到 SQL 公式失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7393555/

相关文章:

java - 在Java Spring 4中从应用程序A到应用程序B进行rest或soap api调用时,将用户名存储在数据库中

java - GUI构建问题

java - 使用 TreeNodes 扩展 Comparable 的广度优先二叉树搜索

java - 构建 3D 建模软件的起点

mysql - 左连接包括主表上的位置

php - undefined variable : tasks (0) when trying to output every database(Tasks) entry associated to one main database entry (Projects)

java - 无法在eclipse中导入hibernate配置文件

java - Hibernate 试图持久化同一个对象两次

php - MYSQL 仅在 INT(11) PHP 时,如果数字长度为 6 位才运行查询

java - 违反约束时静默失败