Hibernate的核心就是对象关系映射,对象和关系型数据库之间的映射通常使用XM了文档来实现。
<?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>
<class name="类名" table="表名">
<id name="属性" type="属性类型">
<column name="表中字段名"/>
<generator class="主键生成策略"/>
</id>
<property name="属性" type="属性类型">
<column name="表字段名"/>
</property>
</class>
</hibernate-mapping>
1、映射内容的定义
<hibernate-mapping package="JavaBean所在包的全路径">
</hibernate-mapping>
hibernate映射文件由hibernate-mapping节点定义映射内容并指定所对应的JavaBean的位置。
也可在该节点下的class节点中的name属性中指定JavaBean的位置
每个.hbm.xml文件都有唯一的一个根元素
2、数据库与JavaBean的关联
<class name="JavaBean名称" table="对应数据库中的表名">
</class>
在父节点中没用package属性指定JavaBean的全路径时,name属性值需要用JavaBean的全路径
3、主键映射
<id name="数据库中主键在JavaBean中的属性名称" column="数据库中表的主键名" type="JavaBean中主键对象属性的类型">
<column name="数据库表中的主键字段名"/>
<!--主键生成策略-->
<generator class="主键映射方式"/>
</id>
该节点必须有且只能有一个(主键只有一个)
该节点必须放于 节点前
hibernate中主键映射方式:
assigned:外部程序对id赋值
native:由数据库对id赋值
identity:采用数据库提供的主键生成机制
increment:主键按照数值顺序递增
sequence:采用数据库提供的sequence机制生成主键
foreign:使用外部表的字段作为主键
。。。。。。
4、普通字段映射
<property name="数据库中字段在JavaBean中的属性名称" column="数据库中的字段名"
type="属性类型">
</property>
<property name="数据库中字段在JavaBean中的属性名称" column="数据库中的字段名"
type="属性类型" not-null="true" >
</property>
5.一对多
<set name="java映射类中对应的属性" inverse="true" lazy="true">
<key column="表中对应字段"/>
<one-to-many class="多方的类"/>
</set>
6.多对一
<many-to-one name="java映射类中对应的属性" column="表中对应字段"
class="类名" not-null="true" />
对于存在一对多关系和多对一关系的双方,需要在…hbm.xml中进行相应配置,这时需要在映射文件中添加。
7.一对一
一对一关系相对一对多关系来说比较少见,但也在某些情况下要用到,例如有一个用户的基本信息表(USER)和一个用户的密码表(PASSWD)就存在一对一的关系。
<!-- 其中主表的配置 -->
<one-to-one name="主表对象中子表对象的属性名" class="子表对象的类名"cascade="save-update"/>
<!-- 子表的配置 -->
<one-to-one name="子表对象中主表对象的属性名" class="主表对象的类名" constrained="true" />```
实例:
![在这里插入图片描述](https://img-blog.csdnimg.cn/2020092809162555.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MjI1ODMzNA==,size_16,color_FFFFFF,t_70#pic_center)