天天看点

hibernate 一对多 关系关联映射

首先在oracle‘【你可以是其他数据库】中建三张表

<!--a表-->

create table a(
id number primary key,
name varchar2(50));

<!--b表-->

creata table b(
id number primary key,
xx varchar2(50));

<!--ab表-->

create table ab(
id number primary key,
a_id number references a(id),
b_id number references b(id));      

之后建立映射

A.hbm.xml

<?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.model.A" table="A" schema="DRDG">
        <id name="id" type="java.math.BigDecimal">
            <column name="ID" precision="22" scale="0" />
            <generator class="native" />
        </id>
        <property name="name" type="java.lang.String">
            <column name="NAME" length="50" />
        </property>
        <set name="abs" inverse="true">
            <key>
                <column name="A_ID" precision="22" scale="0" />
            </key>
            <one-to-many class="com.model.Ab" />
        </set>
    </class>
</hibernate-mapping>
      

B.hbm.xml

<?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.model.B" table="B" schema="DRDG">
        <id name="id" type="java.math.BigDecimal">
            <column name="ID" precision="22" scale="0" />
            <generator class="native" />
        </id>
        <property name="xx" type="java.lang.String">
            <column name="XX" length="50" />
        </property>
        <set name="abs" inverse="true">
            <key>
                <column name="B_ID" precision="22" scale="0" />
            </key>
            <one-to-many class="com.model.Ab" />
        </set>
    </class>
</hibernate-mapping>
      

AB.hbm.xml

<?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.model.Ab" table="AB" schema="DRDG">
        <id name="id" type="java.math.BigDecimal">
            <column name="ID" precision="22" scale="0" />
            <generator class="native" />
        </id>
        <many-to-one name="b" class="com.model.B" fetch="select">
            <column name="B_ID" precision="22" scale="0" />
        </many-to-one>
        <many-to-one name="a" class="com.model.A" fetch="select">
            <column name="A_ID" precision="22" scale="0" />
        </many-to-one>
    </class>
</hibernate-mapping>
      

hibernate.cfg.xml

<?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:@127.0.0.1:1521:orcl
    </property>
    <property name="connection.username">drdg</property>
    <property name="connection.password">zxcvbnm</property>
    <property name="show_sql">true</property>
    <property name="connection.driver_class">
      oracle.jdbc.driver.OracleDriver
    </property>
    <property name="myeclipse.connection.profile">
      oracle.jdbc.driver.OracleDriver
    </property>
    <mapping resource="com/model/Ab.hbm.xml" />
    <mapping resource="com/model/B.hbm.xml" />
    <mapping resource="com/model/A.hbm.xml" />

  </session-factory>

</hibernate-configuration>      

测试类

package com.junit;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.junit.Test;

import com.model.Ab;
import com.util.HibernateSessionFactory;


public class T {

  @Test
  public void t(){
    Session session = HibernateSessionFactory.getSession();
    session.beginTransaction();
    
    List<Ab> ab = null;
    Query q =  session.createQuery("from Ab");
    ab = q.list();
    for(Ab a:ab){
      System.out.println(a.getA().getName());
    }
  }
  
  
}
      

继续阅读