`

3.HIbernate的基本映射

阅读更多

实体类--表

实体类中的普通属性--表字段

 

采用<class>标签映射数据库表,通过<porperty>标签将普通属性映射成表字段。

所谓普通属性指不包括自定义类、集合、数组等。

 

注意:如果实体类和实体类的属性和SQL中的关键字重复,必须使用table或column重新命名。

 

实体类的设计原则:

(1):实现一个默认的(即无参数的)构造方法(constructor)

(2):提供一个标识属性(identifier property)(可选)

(3): 使用非final的类 (可选)

(4):为持久化字段声明访问器(accessors)和是否可变的标志(mutators)(可选)

 

<?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="com.tao.hibernate">
	<class name="Student" table="student" schema="jpa">
		<id name="id" type="java.lang.Integer" column="id">
			<generator class="native" />
		</id>
		<property name="name" type="java.lang.String">
			<column name="name" length="16" />
		</property>
	</class>
</hibernate-mapping>

 

详细介绍:

一:<hibernate-mapping>标签:

<hibernate-mapping
	auto-import="true|false"
	package="package.name"
 />
 

(1):package (可选): 指定一个包前缀,如果在映射文档中没有指定全限定的类名, 就使用这个作为包名。

(2):auto-import(可选 - 默认为 true ):指定我们是否可以在查询语言中使用非全限定的类名(仅限于本映射文件中的类)。

 

二:<class>标签:

<class
	name="ClassName"  
	table="tableName"        
	dynamic-update="true|false"
	dynamic-insert="true|false"       
	lazy="true|false"       
/>
 

(1):name (可选): 持久化类(或者接口)的Java全限定名。 如果这个属性不存在,Hibernate将假定这是一个非POJO的实体映射。

(2):table (可选 - 默认是类的非全限定名): 对应的数据库表名。

(3): dynamic-update (可选, 默认为 false ): 指定用于UPDATE 的SQL将会在运行时动态生成,并且只更新那些改变过的字段。

(4):dynamic-insert (可选, 默认为 false ): 指定用于INSERT 的 SQL 将会在运行时动态生成,并且只包含那些非空值字段。

(5):lazy (可选): 通过设置lazy="false" , 所有的延迟加载(Lazy fetching)功能将被全部禁用(disabled)。

 

三:<id>标签:

<id
	name="propertyName" 
	type="typename"
	column="column_name"
	<generator class="generatorClass"/>
</id>
 

(1):name (可选): 标识属性的名字。

(2):type (可选): 标识Hibernate类型的名字。
(3):column (可选 - 默认为属性名): 主键字段的名字。

 

 

四:<generator>标签:

<id name="id" type="long" column="cat_id">
	<generator class="org.hibernate.id.TableHiLoGenerator">
		<param name="table">uid_table</param>
		<param name="column">next_hi_value_column</param>
	</generator>
</id>
 

(1):class:主键生成器的名称,Hibernate提供了很多内置的实现:

a.increment: 用于为long , short 或者int 类型生成 唯一标识。只有在没有其他进程往同一张表中插入数据时才能使用。 在集群下不要使用。

b.identity

         对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。 返回的标识符是long , short 或者int 类型的。

c.sequence

        在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence), 而在Interbase中使用生成器(generator)。返回的标识符是long , short 或者 int 类型的。

d.uuid

        用一个128-bit的UUID算法生成字符串类型的标识符, 这在一个网络中是唯一的(使用了IP地址)。UUID被编码为一个32位16进制数字的字符串。

e.hilo

        使用一个高/低位算法高效的生成long , short 或者 int 类型的标识符。给定一个表和字段(默认分别是 hibernate_unique_keynext_hi )作为高位值的来源。 高/低位算法生成的标识符只在一个特定的数据库中是唯一的。

f.native

        根据底层数据库的能力选择identity , sequence 或者hilo 中的一个。

g.assigned 让应用程序在save() 之前为对象分配一个标示符。这是 <generator> 元素没有指定时的默认生成策略。

(2):param:生成器实例需要某些配置值或者初始化参数, 用<param> 元素来传递

 

五:<property>标签:

<property
        name="propertyName"
        column="column_name"
        type="typename"
        update="true|false"
        insert="true|false"
        lazy="true|false"
        unique="true|false"
        not-null="true|false"
        length="L"       
/>

(1):name : 属性的名字,以小写字母开头。

(2):column (可选 - 默认为属性名字): 对应的数据库字段名。 也可以通过嵌套的<column> 元素指定。

(3):type (可选): 一个Hibernate类型的名字。

(4):update, insert (可选 - 默认为 true ) : 表明用于UPDATE 和/或 INSERT 的SQL语句中是否包含这个被映射了的字段。这二者如果都设置为false 则表明这是一个“外源性(derived)”的属性,它的值来源于映射到同一个(或多个) 字段的某些其他属性,或者通过一个trigger(触发器)或其他程序生成

(5):lazy (可选 - 默认为 false ): 指定 指定实例变量第一次被访问时,这个属性是否延迟抓取(fetched lazily)( 需要运行时字节码增强)。

(6):unique (可选): 使用DDL为该字段添加唯一的约束。 同样,允许它作为property-ref 引用的目标。

(7):not-null (可选): 使用DDL为该字段添加可否为空(nullability)的约束。

(8):length (可选): 使用DDL为该字段指定长度。

 

 

 

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC 
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
	<class name="com.bjsxt.hibernate.FiscalYearPeriod" table="t_fiscal_year_period">
		<composite-id name="fiscalYearPeriodPK">
			<key-property name="fiscalYear"/>
			<key-property name="fiscalPeriod"/>	
		</composite-id>
		<property name="beginDate"/>
		<property name="endDate"/>
		<property name="periodSts"/>
	</class>
</hibernate-mapping>
 
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC 
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
	<class name="com.bjsxt.hibernate.User" table="t_user">
		<id name="id">
			<generator class="native"/>
		</id>
		<property name="name"/>
		<component name="contact">
			<property name="email"/>
			<property name="address"/>
			<property name="zipCode"/>
			<property name="contactTel"/>
		</component>
	</class>
</hibernate-mapping>
 
分享到:
评论

相关推荐

    org.hibernate.ejb-library-3.4.0.GA-A

    1. `com.springsource.org.hibernate-3.3.2.GA.jar`:这是Hibernate核心库,包含了基本的ORM功能。 2. `com.springsource.javassist-3.15.0.GA.jar`:这是一个Java字节码操作和分析框架,Hibernate使用它来实现动态...

    WebWork.Spring.Hibernate整合开发网络书城

    总的来说,《WebWork.Spring.Hibernate整合开发网络书城》的学习,不仅涵盖了这三个框架的基本用法,还包括了它们如何协同工作,构建出高效、稳定、易于维护的企业级Web应用。通过深入理解和实践,开发者能够提升...

    韩顺平.2011版.hibernate笔记.zip

    3. 实体管理:在Hibernate中,实体类代表数据库中的表,实体对象代表表中的行。笔记讲解了如何定义实体类,如何使用注解或XML进行对象关系映射,以及如何使用Hibernate的API进行持久化操作,如保存(save())、更新...

    08.拓薪教育-hibernate4.3的hibernate.cfg.xml基本配置.part2

    高级Hibernate4开发技术:ORM思想,hibernate介绍,hibernate.cfg.xml配置,hbm.xml映射文件详解,主键生成策略使用,PO对象状态及状态的转换分析、一级缓存,Hibernate数据检索技术,Hibernate高级映射技术,...

    Hibernate关联映射总结

    在探讨Hibernate中的关联映射之前,我们需要先理解几个基本概念,这将有助于我们更好地理解和应用这些关联映射。 - **主键**(Primary Key):主键是用来唯一标识一条记录的关键字段。例如,在一个用户表中,用户ID...

    hibernate基础jar包

    总之,这个压缩包提供了进行Hibernate开发的基本环境,包括了核心库、ORM支持和测试工具,开发者可以基于这些资源快速搭建并测试一个Hibernate项目。在实际开发中,还需要了解和掌握更多关于Hibernate的高级特性和...

    Manning.Java.Persistence.with.Hibernate

    本书不仅覆盖了Hibernate的基本功能,还着重介绍了如何构建和优化工业级别的Hibernate应用程序,是Java开发人员学习和掌握Hibernate的不二之选。 ### Hibernate概述 Hibernate是一个开源的对象关系映射(Object-...

    韩顺平.2011版.hibernate3.3 笔记 ppt 汇总

    3. 实体类和映射文件:讲解如何定义实体类,以及XML或注解方式的映射文件,用于建立对象和表之间的映射关系。 4. Session与Transaction:深入理解Hibernate的Session接口,它是操作数据库的主要接口,以及...

    .hibernate 框架介绍

    Hibernate是一个开源的对象关系映射(ORM)框架,它为Java语言提供了一种方便的工具来操作关系型数据库。Hibernate通过将Java程序中的POJO(普通旧Java对象)映射到数据库表,使得开发者可以使用面向对象的方式来操作...

    hibernate(api 介绍).pdf

    3. org.hibernate.Session Interface:提供了相关的数据库操作,如添、更、删、加、查等基本操作,非线程安全,轻量级,其创建及销毁消耗资源少。每个客户请求对应一个 Session。 4. org.hibernate.Transaction ...

    1.Hibernate-01-基本使用详细大纲1

    1. Hibernate 1.1 和 1.2:早期版本,奠定了 ORM 的基础,提供了一些基本功能。 2. Hibernate 1.2.1 和 1.2.2:对前一版本进行了增强和修复,提高了稳定性。 【ORM 和 Java ORM】 ORM(Object-Relational Mapping...

    Hibernate In Action(Java.Persistence.with.Hibernate)源码

    JPWH可能是这本书的一个简称,这部分代码可能包含了基本的Hibernate设置和使用,例如配置Hibernate的XML或注解方式,实体类的创建,以及如何建立和使用SessionFactory、Session来操作数据库。 通过研究这些源码,你...

    hibernate map 集合映射

    这篇文章将深入探讨Hibernate中的集合映射机制,包括其基本概念、类型以及如何在实际开发中进行配置。 ### 1. Hibernate集合映射的基本概念 集合映射是Hibernate中一个核心的概念,它允许我们将数据库表中的多对一...

    Manning.Java.Persistence.with.Hibernate.Nov.2006

    3. **对象关系映射(ORM)**:阐述如何通过注解或XML映射文件将Java类与数据库表关联,包括属性映射、一对一、一对多、多对一、多对多关系的映射策略。 4. **CRUD操作**:创建(Create)、读取(Read)、更新...

    开发Spring.Struts.Hibernate应用.

    4. **实体类和数据库表映射**:设计业务对象(BO)并用Hibernate的注解或XML配置进行数据库表映射。 5. **Action类**:编写Struts的Action类,这些类通常由Spring管理,实现业务逻辑。 6. **DAO和Service**:创建...

    [原]Hibernate集合映射

    例如,如果集合元素是基本类型,我们可以直接映射;如果是复杂类型的对象,就需要指定对应的实体类。 3. **一对一(One-to-One)映射** 在集合映射中,一对一关系通常表现为单个实体与集合的关系。例如,一个用户...

    基于webwork.hibernate的项目

    Hibernate则是一个对象关系映射(ORM)框架,它允许开发者使用面向对象的方式来操作数据库。通过Hibernate,开发者可以避免编写大量的SQL代码,提高开发效率。Hibernate支持实体类与数据库表之间的映射,提供透明的...

    韩顺平.2011版.hibernate_ppt.zip

    3. **实体类与数据表映射**:Hibernate使用注解或XML文件来定义实体类与数据库表的映射关系,例如`@Entity`、`@Table`等注解用于标识实体类和表,`@Id`表示主键,`@GeneratedValue`处理自增主键。 4. **Session接口...

Global site tag (gtag.js) - Google Analytics