微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – Hibernate:对MySQL使用反引号,但对HSQL不使用反引号

我工作的项目(使用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上也是如此.

最佳答案
后退滴答解决方案听起来不错.但是,如果它不起作用或者您不想使用特定JPA公司的未记录的功能:为什么不使用任何(或最常见的)数据库中未保留的列名.

您无需更改Java属性名称,只能为它们指定列名.

原文地址:https://www.jb51.cc/spring/432154.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐