虽然Hibernate对持久类没有什么要求,可是咱们仍是应该要遵照以下规则:java
#1,提供一个无参的构造方法:全部的持久化类都应该提供一个无参数的构造器,这个构造器能够不采用public访问控制符。所以提供了无参数的构造器,Hibernate就可使用Constructor.newInstance()来建立持久化类的实例了。一般,为了方便Hibernate在运行时生成代理,构造器的访问控制修饰符至少是包可见的,即大于或等于默认的访问控制符。数据库
#2,提供一个标识属性:标识属性一般映射数据库表的主键字段,这个属性能够叫任何名字,其类型能够是任何的基本类型,基本类型的包装类型,java.lang.String或者java.util.Date。若是使用了数据库表的联合主键,甚至能够用一个用户自定义的类,该类拥有这些类型的属性。固然,也能够不指定任何标识属性,而是在映射文件中直接将多个普通属性映射成一个联合主键,但一般不推荐这么作。性能优化
#3,虽然Hibernate能够容许持久化类没有标识符属性,而是让Hibernate内部来追踪对象的识别。但这样作将致使Hibernate许多功能没法使用。并且,Hibernate建议使用能够为空的类型来做为标识属性的类型,所以应该尽可能避免使用基本数据类型。性能
#4,为持久类的每一个属性提供setter和getter方法:Hibernate默认采用属性方式来访问持久化类的属性。若是持久化类有个foo属性,则应该提供setFoo()和getFoo()方法。Hibernate持久化JavaBeans风格的属性,承认以下形式的方法名:getFoo,isFoo和setFoo。若是须要,也能够切换属性的访问策略。优化
#5,使用非final的类:在运行时生成代理是Hibernate的一个重要的功能。若是持久化类没有实现任何接口的话,Hibernate使用CGLIB生成代理,该代理对象是持久化子类的实例。若是使用了final类,则没法生成CGLIB代理,将没法进行性能优化。还有一个可选的策略,让Hibernate持久化类实现一个全部方法都声明为public的接口,此时将使用JDK的动态代理。同时应该避免在非final类中声明public final的方法。若是非要使用一个有public final方法的类,你必须经过设置lazy="false"来明确地禁用代理。代理
#6,重写equals()和hashCode()方法:若是须要把持久化类的实例放入Set中(当须要进行关联映射时,推荐这么作),则应该为该持久化类重写equals()和hashCode()方法。实现equals()和hashCode()最显而易见的方法时比较两个对象标示符的值。若是值相同,则两个对象对应于数据库的同一行,所以它们是相等的(若是都被添加到Set,则在Set中只有一个元素)。遗憾的是,对采用自动生成标识值的对象不能使用这种方法。Hibernate仅为那些持久化对象指定标示值,一个新建立的实例将不会有任何标示值。所以,若是一个实例没有被保存过,但它又确实在一个Set中,保存它将会给这个对象赋一个标识值。若是equals()和hashCode()是基于标示值实现的,则其hashCode返回值会发生改变,这将违反Set的规则。对象