`

Hibernate自增主键

阅读更多

Hibernate自增主键(oracle数据库)可以通过序列来实现。

(1)创建表person和序列person_sequence

 

-----建表-------
create table person(
  id number(10) primary key,
  name varchar2(10) not null,
  age number(3) 
)
-----建序列-----
CREATE SEQUENCE person_sequence 
INCREMENT BY 1 
START WITH 1 
NOMAXVALUE 
NOCYCLE 
CACHE 10; 

 (2)src下新建demo包,包中新建person的pojo类。

 (3)person.java同目录下新建Person.hbm.xml

 

<?xml version="1.0" encoding='UTF-8'?>
<!DOCTYPE hibernate-mapping PUBLIC
                            "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
                            "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" >
<hibernate-mapping package="demo">

    <class name="Person" table="person">
        <id name="id" column="ID" type="int">
         <generator class="native">
           <param name="sequence">person_sequence</param>
         </generator>        
        </id>

        <property name="name" column="NAME" type="string"  not-null="true" />
        <property name="age" column="AGE" type="int" />
    </class>
    
</hibernate-mapping>

 按照这样的配置即可以实现主键的自增。

分享到:
评论

相关推荐

    hibernate联合主键全攻略

    在探讨Hibernate中联合主键的使用时,我们首先需要理解什么是联合主键以及它在Hibernate框架中的实现方式。联合主键(Composite Primary Key),是指在数据库表中使用两个或多个字段共同作为主键来唯一标识每一行...

    hibernate映射主键生成策略native

    ### Hibernate映射主键生成策略native #### 一、引言 在ORM(对象关系映射)技术中,Hibernate作为一款流行的Java持久层框架,在处理数据持久化方面提供了丰富的功能和灵活性。其中,主键生成策略是Hibernate配置...

    Hibernate联合主键的例子

    - 在使用联合主键时,通常不需要生成自增的ID,因为主键是通过组合多个字段生成的。 - 联合主键的每个字段通常都会设置为`@Column(nullable = false)`,确保它们在数据库中都是非空的。 通过以上步骤,你就可以在...

    hibernate复合主键映射

    在Java的持久化框架Hibernate中,复合主键(Composite Key)是一种特殊的数据模型,它用于表示由多个属性共同构成的唯一标识。这种设计通常出现在实体类的某些属性组合起来才能唯一确定一个对象的情况下。本篇文章将...

    Hibernate主键生成策略

    ### Hibernate 主键生成策略详解 #### 一、概述 Hibernate 是一款开源的对象关系映射 (ORM) 框架,它允许开发人员将 Java 对象映射到数据库表中的记录,从而极大地简化了数据访问层的开发工作。在 Hibernate 中,...

    Hibernate的主键生成方式

    - **应用场景**:适合于高并发环境下,且数据库不支持自增主键的场景。 3. **seqhilo** - **定义**:与hilo类似,但是使用数据库序列(sequence)来实现高位值的管理。主要用于Oracle等支持序列的数据库。 - **...

    hibernate的主键生成策略

    在Hibernate中,主键生成策略是确保实体类中的主键字段具有唯一标识的关键部分。以下是对Hibernate主键生成策略的详细说明: 1. **assigned**: 这种策略要求用户在调用`save()`方法之前手动设置主键值。Hibernate...

    hibernate主键生成策略

    - 对于 MySQL 和 SQL Server 数据库,则采用 `Identity` 方式生成自增主键。 - **特点**: - 实现简单,无需过多配置。 - 高度兼容不同数据库。 - 是最常用的主键生成策略之一。 ##### 2. **Assigned** - **...

    Hibernate各种主键生成策略与配置详解

    increment策略由Hibernate在内存中自增生成主键,不依赖于数据库。它通过查询当前表的最大ID值,然后在内存中递增生成新的主键。由于这个过程不是线程安全的,因此在多JVM环境下可能会导致主键冲突。仅适用于单个...

    Hibernate复合主键.

    然而,对于复合主键,一般不推荐使用自增策略,因为复合主键通常由业务数据决定,而不是自动递增。 四、复合主键的持久化操作 在进行增删改查操作时,由于复合主键的存在,我们需要确保所有关联的主键值都被正确...

    Hibernate主键策略-sequence

    Hibernate还提供了其他主键生成策略,如`increment`(适用于单线程环境),`identity`(数据库自增,如MySQL),`table`(通过独立的主键生成表)等,开发者应根据具体需求选择合适的策略。 6. **跨数据库兼容性**...

    hibernate 主键生成策略

    对于 MySQL 和 SQL Server,则使用 identity(自增主键生成机制)。这种方法非常灵活,通常推荐使用。 - **应用场景**:适用于多种数据库环境,尤其是当项目可能跨越不同类型的数据库时。 #### 2. Assigned - **...

    JPA主键策略(针对数据库自增字段重置后无效检查项)

    increment是一种插入数据的时候hibernate会给主键添加一个自增的主键的策略。这种策略维护一个计数器,所以在多个实例运行的时候不能使用这个方法。 foreign foreign是一种使用另外一个相关联的对象的主键的策略。...

    hibernate应用[包括示例,映射,主键自增,各种查询操作方式以及配置文档以及 Annotation示例]

    3. **主键自增**:Hibernate提供了多种主键生成策略,包括自动增长(Identity)、序列(Sequence)等,这些策略确保了每个新创建的对象都有一个唯一的标识。 4. **查询操作**:这包括了HQL(Hibernate Query ...

    真实项目中关于主键生成方式的剖析(JPA)

    而在MySQL和Microsoft SQL Server等数据库中,系统会自动创建并管理自增主键,无需用户干预。 在Oracle中,创建序列并获取下一个值通常通过`Sequence.nextval`方法完成,可以预定义或采用系统默认的参数。序列在...

    Hibernate用UUID作为主键的Demo

    - **隐私保护**:相比自增整型主键,UUID更难以关联到特定的用户或记录。 ### 3. 使用UUID的配置 在Hibernate中,我们可以通过定义主键生成策略来实现UUID的使用。具体做法是在实体类的主键字段上使用`@...

Global site tag (gtag.js) - Google Analytics