Hibernate学习3--Hibernte的映射关系(基础概念篇)

前两节咱们分别从Hibernate的demo和Hibernate的概念上熟悉了Hibernate的使用,这一节咱们来了解Hibernate中的映射关系算法

首先咱们了解下Hibernate映射文件中的各类标签的用法数据库

1<hibernate-mapping>标签:网络

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

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

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

2 <class>标签:
测试

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

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

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

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

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

(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_key 和next_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为该字段指定长度。

接下来的一节咱们看看Hibernate中的一一映射,一多映射,多多映射,复合映射和继承映射。这部份内容比较杂,咱们会根据几个例子一一测试。

相关文章
相关标签/搜索