中文命名之Hibernate 5演示 - 使用注解(annotation)而非xml定义映射
发布日期:2021-06-29 15:32:03 浏览次数:3 分类:技术文章

本文共 1400 字,大约阅读时间需要 4 分钟。

在这里插入图片描述

前文最后留下了个Hibernate 5之后出现的问题, 于是在Hibernate社区提交了报告:

开发组(?Gail Badner)反应很快, 一同确认了当前稳定版5.4.2.Final和最新的6.0.0.Alpha2都有此问题, 并且基于官方测试用例. 初步诊断病因是这个(可以继续深究一下源头, 如果是从其他地方拷贝过来的话). 将此问题添加到了5.4版本的待修复问题列表, 并建议用注解(annotation)而不是xml配置. 经测试的确可通过注解支持与前文相同的中文命名.

完整源码在此分支:

带注解的Java源码:

@Entity@Table(name="客户")public class 客户类 implements java.io.Serializable {
private Long 客户_ID; private String 姓名; private Date 创建日期; public 客户类() {
} public 客户类(String 姓名, Date 创建日期) {
this.姓名 = 姓名; this.创建日期 = 创建日期; } @Id @GeneratedValue(strategy=GenerationType.IDENTITY) @Column(name = "客户_ID", length=20) public Long get客户Id() {
return this.客户_ID; } public void set客户Id(Long 客户Id) {
this.客户_ID = 客户Id; } @Column(name = "姓名", nullable = false, length=45) public String get姓名() {
return this.姓名; } public void set姓名(String 姓名) {
this.姓名 = 姓名; } @Column(name = "创建日期", nullable = false, length=19) public Date get创建日期() {
return this.创建日期; } public void set创建日期(Date 创建日期) {
this.创建日期 = 创建日期; } @Override public String toString() {
return 客户_ID + " " + 姓名 + " " + 创建日期; }}

在Hibernate配置文件中指定类, 而非xml映射文件:

期间碰到一个问题:

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column ‘客户类0_.客户Id’ in ‘field list’

是由于id的默认数据库列名为Id, 而数据库中使用了客户_ID作为列名. 添加如下注解后解决:

@Column(name = "客户_ID", length=20)

参考

转载地址:https://codeinchinese.blog.csdn.net/article/details/90261890 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:从立创EDA,Gratipay看中文编程开发环境和推广运营的一个趋势
下一篇:中文方便就用中文编程!Python图形界面开发实例

发表评论

最新留言

初次前来,多多关照!
[***.217.46.12]2024年04月18日 04时37分31秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章