xml 代码
- <id name=”id” column=”id” type=”java.lang.Integer”>
- <generator class=”native”/>
- id>
上面是一个简单的id映射配置,id属性对应映射类中的属性,column对应数据库中表字段。
重点是这个generator<generator></generator><generator class="native"></generator><generator class="”native”"></generator>,其中class属性可以有以下几种可选类型。
l Assigned
主键由应用逻辑产生,即我们在代码里面指定id,数据交由Hibernate保存时,主键已经设置完成,无需Hibernate干预。
l <st1:place w:st="on"><st1:city w:st="on">hilo</st1:city></st1:place>
通过hi/lo算法实现的主键生成机制,需要额外的数据库表保存主键生成历史状态。
l seqhilo
与hilo类似,通过hi/lo算法实现的主键生成机制,只是主键历史状态保存在Sequence里,适合于支持sequence的数据库,例如Oracle。
l increment
主键按数值顺序递增。此方式的实现机制为在当前应用实例中维持一个变量,以保存着当前的最大值,之后每次需要生成主键的时候将此值加1生成主键。这种方式产生的问题是:如果当前有多个实例访问数据库,那么由于各个实例各自维护主键状态,不同实例可能生成同样的主键,从而造成主键重复异常。因此如果同一数据库由多个实例访问,必须避免这种方式。
l identity
采用数据库提供的主键生成机制,如SQLServer、MYSQL提供的自增主键生成机制。
l sequence
采用数据库提供的sequence机制生成主键,如Oracle sequence。
l native
同hibernate根据数据库适配器中的定义,自动采用identity、hilo、sequence中的一种作为主键生成机制。
l uuid.hex
由hibernate基于128位惟一值产生算法,根据当前设备IP,时间,JVM启动时间,内部自增量等四个参数生成16进制数值(编码后以32位的字符串表示)作为主键。
l uuid.string
和uuid.hex类似,只是生成的主键未生成编码(长度16位),在某些数据库中可能出现问题,如PostgreSQL。
l foreign
使用外部表的字段作为主键。
l select
hibernate3中引入新的主键生成机制,主要针对遗留系统的改造工程。
(摘自《深入浅出Hibernate》)
分享到:
相关推荐
比如,如果你有一个User类,其有id、username和email属性,对应的SQL查询可能是"SELECT id, username FROM User",而在HQL中,这个查询会写成"SELECT u.id, u.username FROM User u"。这里的"u"是User类的一个别名,...
2. **@Id**:标识实体类的主键,可以通过`@GeneratedValue(strategy=GenerationType.IDENTITY)`设置自增策略。 3. **字段映射**:如`@Column(name="column_name")`将字段映射到表的列。 4. **关系映射**:注解如`@...
在Java世界中,ORM(对象关系映射)框架如Hibernate极大地简化了数据库操作。本篇主要探讨的是Hibernate中的继承映射策略,特别是“每个子类一张表”(Table per subclass)的方式。这种方式也被称为单表继承或多表...
第2课 Hibernate UML图 6 第3课 风格 7 第4课 资源 7 第5课 环境准备 7 第6课 第一个示例Hibernate HelloWorld 7 第7课 建立Annotation版本的HellWorld 9 第8课 什么是O/R Mapping 11 一、 定义: 11 二、 Hibernate...
在Java的持久化框架Hibernate中,ID生成策略是至关重要的一个环节。它是用来唯一标识数据库中每一行记录的关键部分。本教程将详细讲解Hibernate中的ID生成策略,以及如何在实际项目中灵活应用。 首先,ID生成策略是...
此时,对象未被Hibernate管理,即使对象包含了主键ID,如果这个ID在数据库中不存在,或者没有设置ID,Hibernate也不会将其与数据库中的任何记录关联。如果在临时状态下执行`delete`操作,由于对象尚未与数据库连接,...
2. **Hibernate Commons Annotations**:这个库提供了一些常见的JPA注解,如@Entity、@Table、@Id等,使得开发者可以方便地定义Java实体类和它们与数据库表的映射关系。 3. **Hibernate EntityManager**:这是JPA...
- `@Id`:标识类的某个属性为表的主键,通常配合@GeneratedValue使用来自动生成主键值。 - `@GeneratedValue`:定义主键生成策略,如AUTO、IDENTITY、SEQUENCE等。 2. **属性注解**: - `@Column`:用于指定实体...
例如,`@Entity`表示这个类对应一个数据库表,`@Table(name="table_name")`指定表名,`@Id`标记主键字段,`@Column`定义字段属性等。通过这些注解,Hibernate能理解类的结构并据此生成数据库表。 5. **Hbm2DDL Auto...
在Java开发中,Hibernate是一个非常流行的对象关系映射(ORM)框架,它允许开发者使用面向对象的方式处理数据库操作。在本教程中,我们将探讨如何利用Hibernate的注解功能,通过实体类自动生成数据库中的表。这极大...
Hibernate,作为一个开源的Java ORM(对象关系映射)框架,自1999年发布以来,已经在Java开发领域占据了举足轻重的地位。它极大地简化了数据库操作,使得开发者能够用面向对象的方式来处理数据库,无需直接编写SQL...
例如,@Entity表示实体类,@Id表示主键,@GeneratedValue指定主键生成策略。 5. CRUD操作: Hibernate通过Session接口提供了便捷的CRUD(Create、Read、Update、Delete)操作。如save()、get()、update()、delete...
- **实体管理**:通过@Entity注解定义实体类,通过@Table指定对应数据库表,通过@Column、@Id等注解定义字段属性。 - **持久化操作**:通过SessionFactory创建Session,Session是与数据库交互的主要接口,支持CRUD...
- `@Id`:指定主键字段。 - `@GeneratedValue`:控制主键生成策略,如自动增长、序列等。 - `@Column`:映射属性到数据库列,可以设置长度、精度等属性。 - `@OneToMany`, `@ManyToOne`, `@OneToOne`, `@...
- @Id:标识类中的主键字段,可以配合@GeneratedValue指定主键生成策略。 - @GeneratedValue:定义主键的自增策略,如IDENTITY(数据库自动增长)、SEQUENCE(序列)等。 - @Column:定义属性对应表中的列,可以...
- Entity:代表数据库中的表,通过@Entity注解标识,使用@id指定主键。 - Mapping:定义了Java类与数据库表之间的映射关系,通常使用XML或注解方式完成。 4. Hibernate操作流程: - 配置:创建Configuration对象...
7. **实体类和表映射**:使用Hibernate注解(如@Entity, @Table, @Id, @GeneratedValue等)将Java类映射到数据库表。 8. **事务管理**:Hibernate支持JTA(Java Transaction API)和编程式事务管理,确保数据库操作...
例如,创建一个名为`guestbook`的表,包含`id`、`title`、`content`、`author`、`email`和`createtime`等字段。这可以通过SQL脚本完成。 2. **配置MyEclipse的Hibernate支持**: - 打开MyEclipse的首选项设置(`...