Hibernate
-
Hibernate的核心是对象关系的映射,对象和关系型数据库之间的映射通常使用XML文档来实现,映射文件的命名规则为*.hbm.xml;
-
<hibernate-mapping package = "JavaBean所在包全路径"> </hibernate-mapping>
hibernate映射文件由hibernate-mapping节点定义映射内容并且指定所对应的JavaBean的位置
每个*.hbm.xml文件都有唯一一个根元素 <hibernate-mapping
-
数据库与JavaBean的关联
<class name = "JavaBean名称" table="对应数据库表名"> </class>
在父节点< hibernate-mapping >中没用package属性指定JavaBean全路径时,name属性值需要用到JavaBean的全路径
-
主键映射
<id name="数据库中主键在JavaBean中的属性名称" column="数据库中表的主键名" type="JavaBean中主键对象属性的类型"> <column name="数据库表中的主键字段名"> <!--主键生成策略--> <generator class="主键映射方式"/> </id>
该节点有且仅有一个,因为主键只有一个
该节点必须放在< property > 节点前
hibernate中主键映射方式:
.assigned:外部程序对id赋值
.native:由数据库对id赋值
.identity:采用数据库提供的主键生成机制,如DB2、SQL Server、MySQL中的主键生成机制。
.increment:主键按照数值顺序递增
.sequence:采用数据库提供对的sequence机制生成主键
.foreign:使用外部表的字段作为主键
- 普通字段映射
<property name = "数据库中字段在JavaBean中的属性名称" column="数据库中的字段名" type="属性类型" >
</property>
<property name = "数据库中字段在JavaBean中的属性名称" column="数据库中的字段名 type="属性类型" not-null="true">
</property>
节点映射普通字段,该节点可有多个,一个字段用一个节点映射
- 一对多关系
一对多关系一般是用在一个表与另一个表存在外键(如果一张表中有一个非主键的字段指向了别一张表中的主键,就将该字段叫做外键,一张表中可以有多个外键)关联的时候
例如用户表的组织id与组织表存在外键关联,则“一”方为组织表,“多”方为用户表,因为一个组织可以包含多个用户,而一个用户只能隶属于一个组织。
对于存在一对多关系和多对一关系的双方,需要在*.hbm.xml中进行相应配置,这时在“一”方(例如:组织)需要在映射文件中添加
<set name="java映射类中对应的属性 " inverse="true" lazy="true">
<key column="表中对应字段"/>
<one-to-many class="多方的类"/>
</set>
many-to-one方式:
<many-to-one name="java映射类中对应的属性" column="表中对应字段" class="类名" not-null="true" />
- 一对一关系
例如一个用户的基本信息表(USER)和一个用户的密码表(PASSWORD)就存在一对一的关系。
主表的配置:
<one-to-one name="主表对象中子表对象的属性名" class="子表对象的类名"cascade="save-update"/>
子表配置:
<one-to-one name="子表对象中主表对象的属性名" class="主表对象的类名" constrained="true" />
- 多对多关系
在数据库设计时,一般将多对多关系转换为两个一对多(或者多对一)关系
cascade属性的可能值有
all: 所有情况下均进行关联操作,即save-update和delete。
none: 所有情况下均不进行关联操作。这是默认值。
save-update: 在执行save/update/saveOrUpdate时进行关联操作。
delete: 在执行delete 时进行关联操作。
原文作者:
Lambo Chen
原文链接:https://blog.csdn.net/chensanwa/article/details/79176090