Hibernate学习笔记二

Map映射关系:

1)

Team.java:

   private Stringid;

   private StringteamName;

   privateMap students;

为其生成setget方法。

Team.hbm.xml:

<classname="com.songjinghao.hibernate.Team"table="team">

         <idname="id"column="id"type="string">

        <generatorclass="uuid"></generator>

      </id>

       <propertyname="teamName"column="teamName"type="string"></property>

      <mapname="students"table="student">

        <keycolumn="team_id"></key>

        <indexcolumn="name"type="string"></index> <!-- 指定的是Map中的key -->

        <elementcolumn="decription"type="string"></element> <!-- 指定的是Map中的value -->

      </map>    

</class>

 

2)

Team.java:

1)中相同。

 

Student.java:

   private Stringid

   private Stringname;

   private StringcardId;

   privateintage;

   private Teamteam;

为其生成setget方法。

Team.hbm.xml:

<classname="com.songjinghao.hibernate.Team"table="team">

      < id name = "id" column = "id" type = "string" >

        <generatorclass="uuid"></generator>

      </id>

      < property name = "teamName" column = "teamName" type = "string" ></ property >

      <mapname="students"table="student"cascade="all">

        <keycolumn="team_id"></key>

        <indexcolumn="card_id"type="string"></index> <!-- 指定的是Map中的key -->

        <one-to-manyclass="com.songjinghao.hibernate.Student"/>

      </map>    

</class>

 

Student.hbm.xml:

<classname="com.songjinghao.hibernate.Student"table="student">

      <idname="id"column="id"type="string">

        <generatorclass="uuid"></generator>

      </id>

      <propertyname="cardId"column="card_id"type="string"></property>

      <propertyname="name"column="name"type="string"></property>

      <propertyname="age"column="age"type="integer"></property>

      <many-to-onename="team"class="com.songjinghao.hibernate.Team"column="team_id"></many-to-one>

</class>

 

总结:

mapset标签中的element子标签映射的是原子类型(stringdateintlong…),即能够直接映射到数据库表字段上的类型,而one-to-many映射的则是实体类型,指的是无法映射到表的某个字段,而是要映射到整张表的类型。

 

List映射关系:

 

Team.java:

   private Stringid;

   private StringteamName;

   privateList students =newArrayList();

为其生成setget方法。

Student.java:

   private Stringid;

   private StringcardId;

   private Stringname;

   privateintage;

   private Teamteam;

为其生成setget方法。

 

Team.hbm.xml:

<classname="com.songjinghao.hibernate.Team"table="team">

      <idname="id"column="id"type="string">

        <generatorclass="uuid"></generator>

      </id>

      <propertyname="teamName"column="teamName"type="string"></property>

       <listname="students"table="student"cascade="all">

         <key column="team_id"></key>

         <index column="index_"></index> <!-- 对应于一的一方的多的一方的索引值 -->

         <one-to-many class="com.songjinghao.hibernate.Student"/>

</list>

 

Student.hbm.xml:

<classname="com.songjinghao.hibernate.Student"table="student">

      <idname="id"column="id"type="string">

        <generatorclass="uuid"></generator>

      </id>

      <propertyname="cardId"column="card_id"type="string"></property>

      <propertyname="name"column="name"type="string"></property>

      <propertyname="age"column="age"type="integer"></property>

      <many-to-onename="team"column="team_id"class="com.songjinghao.hibernate.Team"></many-to-one>  

</class>

 

Bag映射关系:

 

因为Bag要用List模拟,Team.javaStudent.java代码List映射关系的一样。

Student.hbm.xml也没有变化。


Team.hbm.xml:

<classname="com.songjinghao.hibernate.Team"table="team">

      <idname="id"column="id"type="string">

        <generatorclass="uuid"></generator>

      </id>

      <propertyname="teamName"column="teamName"type="string"></property>

       <bagname="students"table="student"cascade="all"inverse="true">

         <key column="team_id"></key>

         <one-to-many class="com.songjinghao.hibernate.Student"/>

       </bag>

</class>

 

总结:

inverse的设置问题:有序的让一的一方去维护。

Bag (结合了 List Set ),可以重复且没有顺序的一种集合,是 Hibernate 提供的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值