前文中文编程:中文命名之Hibernate 4+MySQL演示最后留下了个Hibernate 5以后出现的问题, 因而在Hibernate社区提交了报告: Seemingly regression since Hibernate 5: unicode support for class name in XML mapping filehtml
开发组(👍Gail Badner)反应很快, 一同确认了当前稳定版5.4.2.Final和最新的6.0.0.Alpha2都有此问题, 而且基于官方测试用例重现了问题. 初步诊断病因是这个xsd约束(能够继续深究一下源头, 若是是从其余地方拷贝过来的话). 将此问题添加到了5.4版本的待修复问题列表, 并建议用注解(annotation)而不是xml配置. 经测试的确可经过注解支持与前文相同的中文命名.java
完整源码在此分支: nobodxbodon/HibernateExampleZhmysql
带注解的Java源码:git
@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映射文件:github
<mapping class="com.codeinchinese.客户.模型.客户类"></mapping>
期间碰到一个问题:sql
Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column '客户类0_.客户Id' in 'field list'数据库
是因为id的默认数据库列名为Id, 而数据库中使用了客户_ID做为列名. 添加以下注解后解决:编程
@Column(name = "客户_ID", length=20)
Chapter 2. Mapping Entitiesapp
org.hibernate.MappingException: Unknown entity: annotations.Userside