hIBERNATE多对多关联

1.配置文件

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
          "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<!-- Generated by MyEclipse Hibernate Tools.                   -->
<hibernate-configuration>

<session-factory>
 <property name="dialect">
  org.hibernate.dialect.Oracle9Dialect
 </property>
 <property name="connection.url">
  jdbc:oracle:thin:@localhost:1521:orcl
 </property>
 <property name="connection.username">test</property>
 <property name="connection.password">123</property>
 <property name="connection.driver_class">
  oracle.jdbc.OracleDriver
 </property>
 <property name="myeclipse.connection.profile">yh</property>
 <property name="show_sql">true</property>
 <property name="format_sql">true</property>
 <mapping resource="com/yh/entity/Users2.hbm.xml" />
 <mapping resource="com/yh/many2many/entity/Emps.hbm.xml" />
 <mapping resource="com/yh/many2many/entity/Project.hbm.xml" />
 <mapping resource="com/yh/entity/Customer.hbm.xml" />

</session-factory>

</hibernate-configuration>

================================================================================================

2.映射文件

<?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">
 <!--
  Mapping file autogenerated by MyEclipse Persistence Tools
 -->
<hibernate-mapping>
 <class name="com.yh.many2many.entity.Emps" table="EMPS" schema="TEST">
  <id name="empid" type="java.lang.Short">
   <column name="EMPID" precision="4" scale="0" />
   <generator class="assigned" />
  </id>
  <property name="empname" type="java.lang.String">
   <column name="EMPNAME" length="40" />

================================================================================================

3.映射文件

<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
 <!--
  Mapping file autogenerated by MyEclipse Persistence Tools
 -->
<hibernate-mapping>
 <class name="com.yh.many2many.entity.Project" table="PROJECT"
  schema="TEST">
  <id name="proid" type="java.lang.Short">
   <column name="PROID" precision="4" scale="0" />
   <generator class="assigned" />
  </id>
  <property name="pname" type="java.lang.String">
   <column name="PNAME" length="40" />
  </property>
  <set name="emps" table="emppro" cascade="all">
   <key column="rproid"></key>
   <many-to-many column="rempid" class="com.yh.many2many.entity.Emps"></many-to-many>
  </set>
 </class>
</hibernate-mapping>

  </property>
  
  <set name="pros" table="emppro"  cascade="all">
   <key column="rempid"></key>
   <many-to-many class="com.yh.many2many.entity.Project"
    column="rproid"></many-to-many>
  </set>
 </class>
</hibernate-mapping>


================================================================================================

3.实体类

public class Emps implements java.io.Serializable {

 // Fields

 private Short empid;
 private String empname;
 private Set<Project> pros=new HashSet<Project>();




public class Project implements java.io.Serializable {

 // Fields

 private Short proid;
 private String pname;
 private Set<Emps> emps = new HashSet<Emps>();

================================================================================================

4.添加测试

public class EmpTest {

 @Test
 public void addDept() {
  Session session = null;
  Transaction tx = null;

  // 实体化部门对象
  Dept dept = new Dept();
  dept.setDeptno(70);
  dept.setDname("后勤部");
  dept.setLoc("郑州");

  // 员工对象
  Employee e1 = new Employee();
  e1.setEname("张三");
  

  Employee e2 = new Employee();
  e2.setEname("李四");

  // 将员工添加到部门中
  Set<Employee> set = new HashSet<Employee>(0);
  set.add(e1);
  set.add(e2);
  dept.setEmployees(set);

  try {
   session = HibernateUtil.currentSession();
   tx = session.beginTransaction();
   // session.save(e1);
   // session.save(e2);
   session.save(dept);// 保存部门
   tx.commit();
  } catch (HibernateException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
   tx.rollback();
  } finally {
   HibernateUtil.closeSession();
  }

 }}


================================================================================================



================================================================================================


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值