ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

hibernate 一对多 关系关联映射

2021-06-02 10:02:03  阅读:150  来源: 互联网

标签:xml hibernate 映射 number 关联 ab import id


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


下载地址:http://download.csdn.net/detail/yao__shun__yu/5087574

标签:xml,hibernate,映射,number,关联,ab,import,id
来源: https://blog.51cto.com/u_14943622/2844515

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有