gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 07:33:32 25 4
gpt4 key购买 nike

我刚刚从 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com