我刚刚从 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 上尝试了 registerFunction
和 registerKeyword
但没有任何运气,因为它们似乎与 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/