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