我工作的项目(使用Java,Spring,Hibernate)最近从Oracle改为MySQL.在某些情况下,代码中的某些属性是MysqL中的保留字,例如“release”.
有一些解决方案,1)重命名代码中的属性和后续的getter / setter方法,还更新调用这些方法的代码2)使用@Column(name =“`release`”)在代码中注释属性.这告诉hibernate在与数据库交谈时引用该名称.
我宁愿远离第一种方法来减少破坏更多东西的机会.第二种方法是“ok”,除了它特定于MysqL.在我们的开发中.设置我们使用Hsql,它不喜欢这些列名称的反引号.
我查看了org.hibernate.mapping.Column类,我发现它有“getQuotedName”方法,如果我可以继承Column并告诉Hibernate使用我自己的Column类,我可能会覆盖这些方法.
基于以下首选方法解决此问题的最佳方法是:a)不必重构代码库(b / c更改属性名称,getter / setter方法等)和b)希望应用程序仍然可以在Hsql中工作MysqL的.
在属性文件中具有可以切换以打开/关闭某些列命名修复的属性是合理的.这提醒我,我尝试使用自定义命名策略并覆盖“columnName”方法来围绕反引号中的列名称…这不起作用,即使在MysqL上也是如此.
最佳答案