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>标签,则默认为

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

时间: 2025-01-09 06:10:31

Hibernate实体类编写规则和主键策略的相关文章

Hibernate实体类编写规则

Hibernate 实体类编写规则 1 实体类里面属性私有的   2 私有属性使用公开的set和get方法操作   3 要求实体类有属性作为唯一值(一般使用id值)   4 实体类属性建议不使用基本数据类型,使用基本数据类型对应的包装类 (1)八个基本数据类型对应的包装类 - int - Integer - char - Character - 其他的都是首字母大写 比如 - double - Double - long - Long - short - Short - float - Floa

实体类编写规则

-------------------siwuxie095 实体类编写规则 1.实体类里面的属性是私有的 2.私有属性使用公有的 get 和 set 方法进行操作 3.要求实体类有一个属性作为唯一值(一般使用 id 值) 「实体类要有一个唯一标识的 OID 与表的主键对应」 4.实体类属性建议不使用基本数据类型,而使用基本数据类型对应的包装类 (1)八个基本数据类型对应的包装类 1)int - Integer 2)char - Character 3)其它都是直接首字母变为大写,如:double

Hibernate入门(二)之hibernate的内部执行过程,主键生成器,对象的状态

内部执行过程 主键生成器 Identity(常用) 1.表必须支持自动增长机制 2.数据库生成主键 3.不需要在程序中设置主键 Assigned 必须通过程序的方式给值才可以 person.setId(xxx): 一般用于开发的时候测试使用 Increment(常用) 1.如果选择该主键的生成方式,则必须是数字类型 2.先获取主键的最大值,在最大值的基础上加1,形成新的主键 3.效率比较低,因为这种方式会先select表中最大的主键值 4.主键的生成是由hibernate内部实现的 native

【求助】因为相同类型的其他实体已具有相同的主键值。在使用 &quot;Attach&quot; 方法或者将实体的状态设置为 &quot;Unchanged&quot; 或 &quot;Modified&quot; 。。。

因为相同类型的其他实体已具有相同的主键值.在使用 "Attach" 方法或者将实体的状态设置为 "Unchanged" 或 "Modified" 时如果图形中的任何实体具有冲突键值,则可能会发生上述行为.这可能是因为某些实体是新的并且尚未接收数据库生成的键值.在此情况下,使用 "Add" 方法或者 "Added" 实体状态跟踪该图形,然后将非新实体的状态相应设置为 "Unchanged"

Hibernate 主键策略

Hibernate主键生成策略 1.自动增长identity 适用于MySQL.DB2.MS SQL Server,采用数据库生成的主键,用于为long.short.int类型生成唯一标识 使用SQL Server 和 MySQL 的自增字段,这个方法不能放到 Oracle 中,Oracle 不支持自增字段,要设定sequence(MySQL 和 SQL Server 中很常用) 数据库中的语法如下: MySQL:create table t_user(id int auto_increment

JPA主键策略

JPA 自带的主键策略有 4 种,在枚举 javax.persistence.GenerationType 中,分别是:TABLE.SEQUENCE.IDENTITY.AUTO. TABLE:通过表产生主键,框架借由表模拟序列产生主键,使用该策略可以使应用更易于数据库移植.不同的JPA实现商生成的表名是不同的,如OpenJPA生成openjpa_sequence_table表,Hibernate生成一个hibernate_sequences表,而TopLink则生成sequence表.这些表都具

【hibernate】 hibernate的主键策略

今天使用maven生成一个sping+springMVC+hibernate 的项目,报错如下: 错误提示呢:不能解释这个id的生成策略[uuid.string].就是uuid.string这个hibernate不支持. 奇怪了, 网上查看别人的问题,有提到这个东西: 1 1. Changes in version 3.0 beta 1 (21.12.2004) 2 2. * removed uuid.string and renamed uuid.hex to plain uuid 在hibe

hibernate框架学习笔记4:主键生成策略、对象状态

创建一个实体类: package domain; public class Customer { private Long cust_id; private String cust_name; private String cust_source; private String cust_industry; private String cust_level; private String cust_linkman; private String cust_phone; private Stri

关于hibernate查询视图时,相同主键的两条记录映射问题【已解决】

做项目中间遇到一个很诡异的问题: 有两个表:A和AHistory(A表记录删除后存入此表,A的历史表),当我复制一条记录到AHistory表时,此时A表和AHistory表两条记录id相同,后续通过修改操作将两表任意一条记录更新为不同的信息,但ID仍然相同:此时,如果用hibernate映射到实体类中时,想象中的应该是两个不同的实体类,拥有不同的属性等. 然而,当我在程序中查询这两条ID相同的记录后,所得到两个的hibernate映射实体类却完全相同. 通过此问题,才知道hibernate会将查