Hibernate实体类编写规则和主键策略

Posted 一条路上的咸鱼

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Hibernate实体类编写规则和主键策略相关的知识,希望对你有一定的参考价值。

一、实体类的编写规则

  1、属性要是私有的。

    

  2、要有公开的setter和getter方法供外界访问和修改。

    

 

  3、每一个实体类要有一个属性作为唯一值(一般都是使用对于数据表的主键)。

    

 

  4、建议数据类型不要使用基本的数据类型,而是使用相应的包装类。

    

  5、Java中对应的包装类

基本数据类型 对应包装类
int Integer
char Character
boolean Boolean
float Float
double Double
short Short
long Long
byte Byte

 

    使用包装类的原因:因为有时候使用基本数据类型无法准确表示一些场景。

             例:score代表学生的成绩,但是在考试时可能存在缺考的情况,如果使用int数据类型,则score = 0表示考了分,但是缺考还是score =

               0,这样无法区分;如果使用Integer,则要是缺考,score = null;这样就可以区分是考了0分还是缺考。

 

二、主键生成策略

    1、Hibernate要求在一个实体中必须要有一个属性作为唯一值,这个唯一值一般都对应表中的主键。

    2、主键分类

      自然主键:把具有业务含义的字段作为主键,称之为自然主键。

      代理主键:把不具有业务含义的字段作为主键,称之为代理主键。

    3、主键的常见生成策略有七种

      (1)increment :用于long、short或int类型的,由Hibernate自动由递增的方式生成唯一标识符,每次增长1.

               只有当没有其他线程向同一张表中插入数据时使用。不能在集群情况下使用,适用于代理主键。

      (2)identity:采用底层数据库提供的本身提供的主键生成标识符,前提是数据库必须支持自增长的数据类型。

              在DB2、mysql、MS SQL SERVER、Sybase和HypersonicSQL数据库中可以使用该策略,该策略

              要求在数据库中把主键定义为自增长,适用于代理主键。

      (3)sequence:Hibernate根据底层数据库序列生成标识符。条件是数据库要支持序列,Oracle数据库可以使用该策略

               适用于代理主键。

      (4)hilo:hilo:通过hi/lo 算法实现的主键生成机制,需要额外的数据库表保存主键生成历史状态。

      (5)native:根据底层数据库对自动生成表示符的能力来自动选择identity、sequence和hilo三种生成器中的一种。

              适合跨数据库平台开发,适用于代理主键。

      (6)uuid:Hibernate采用128位的UUID来生成字符,使用16进制表示,使用该策略时主键必须定义为String类型,

             由于其所占的空间较多,使用较少,适用于代理主键。

      (7)assigned:由Java程序负责生成标识符,如果在配置文件中不配置<generator></generator>标签,则默认为

              该策略,适用于自然主键。

以上是关于Hibernate实体类编写规则和主键策略的主要内容,如果未能解决你的问题,请参考以下文章

三大框架 之 Hibernate生成策略与缓存策略(主键生成策略持久化持久化类划分一级缓存事物管理)

hibernate框架持久化类&主键生成策略

Hibernate主键生成策略

Hibernate主键生成策略

Hibernate 表映射 主键生成策略与复合主键

hibernate中实体类注解