hIBERNATE多对多关联

原创 2016年05月30日 19:06:22

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();
  }

 }}


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



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



Hibernate多对多双向关联

以Student和Course为例,一个学生可以选多门课程,一门课程也可以被多个学生选取; 持久化类Student: package bean; import java.util.Set; ...
  • jialinqiang
  • jialinqiang
  • 2013年03月21日 11:49
  • 15036

hibernate多对一关联和一对多关联

1. 多对一的单向关联 从订单(order)到客户(customer)的单向关联 (多个订单对应一个客户) JavaBean: Customer public class Customer{ pr...
  • zdp072
  • zdp072
  • 2016年04月13日 20:20
  • 1672

Hibernate一对多关联映射(注解)

Hibernate一对多关联映射,维护端(一方,无外键方)可以进行关联移除,级联删除,级联保存,级联更新,级联刷新。被维护端(多方,外键方),不可以进行关联移除,级联操作,只能级联刷新。   ...
  • hardworking0323
  • hardworking0323
  • 2016年04月10日 18:35
  • 2715

hibernate多对多关联映射

  • 2013年07月30日 23:53
  • 790KB
  • 下载

hibernate双向多对多关联映射(注解版)

  • 2017年05月07日 17:41
  • 16KB
  • 下载

Hibernate多对多关联关系demo

  • 2015年04月10日 10:30
  • 792KB
  • 下载

Hibernate教程14_关系映射之多对多双向关联

  • 2013年04月13日 14:10
  • 7.38MB
  • 下载

hibernate多对多关联的问题

  • 2014年06月19日 17:04
  • 28KB
  • 下载

hibernate实现多对多关联关系源码

  • 2015年10月09日 19:14
  • 9.05MB
  • 下载

hibernate关联映射详解SSH 多对多,一对多关系对象映射

  • 2012年04月21日 23:41
  • 24KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:hIBERNATE多对多关联
举报原因:
原因补充:

(最多只允许输入30个字)