标签: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. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。