如果持久性类的列表对象包含实体引用, 则需要使用一对多关联来映射列表元素。
在这里, 我们使用的是论坛的场景, 其中一个问题有多个答案。
文章图片
在这种情况下, 一个问题可能有很多答案, 每个答案可能都有自己的信息, 这就是为什么我们在持久性类(包含Answer类的引用)中使用列表来表示答案的原因。
让我们看看具有列表对象(包含Answer类对象)的持久类。
package com.srcmini;
import java.util.List;
public class Question {
private int id;
private String qname;
private List<
Answer>
answers;
//getters and setters}
【使用XML的Hibernate一对多示例】Answer类具有自己的信息, 例如id, answername, postedBy等。
package com.srcmini;
public class Answer {
private int id;
private String answername;
private String postedBy;
//getters and setters}
}
Question类具有具有实体引用的列表对象(即Answer类对象)。在这种情况下, 我们需要使用一对多列表来映射该对象。让我们看看如何映射它。
<
list name="answers" cascade="all">
<
key column="qid">
<
/key>
<
index column="type">
<
/index>
<
one-to-many class="com.srcmini.Answer"/>
<
/list>
按列表在Hibernate中一对多映射的完整示例
在此示例中, 我们将看到包含实体引用的映射列表的完整示例。
1)创建持久性类
该持久类定义了包含List的类的属性。
Question.java
package com.srcmini;
import java.util.List;
public class Question {
private int id;
private String qname;
private List<
Answer>
answers;
//getters and setters}
Answer.java
package com.srcmini;
public class Answer {
private int id;
private String answername;
private String postedBy;
//getters and setters}
}
2)为持久化类创建Mapping文件
在这里, 我们创建了用来定义列表的question.hbm.xml文件。
<
?xml version='1.0' encoding='UTF-8'?>
<
!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 5.3//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-5.3.dtd">
<
hibernate-mapping>
<
class name="com.srcmini.Question" table="q501">
<
id name="id">
<
generator class="increment">
<
/generator>
<
/id>
<
property name="qname">
<
/property>
<
list name="answers" cascade="all">
<
key column="qid">
<
/key>
<
index column="type">
<
/index>
<
one-to-many class="com.srcmini.Answer"/>
<
/list>
<
/class>
<
class name="com.srcmini.Answer" table="ans501">
<
id name="id">
<
generator class="increment">
<
/generator>
<
/id>
<
property name="answername">
<
/property>
<
property name="postedBy">
<
/property>
<
/class>
<
/hibernate-mapping>
3)创建配置文件
该文件包含有关数据库和映射文件的信息。
<
?xml version='1.0' encoding='UTF-8'?>
<
!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 5.3//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-5.3.dtd">
<
!-- Generated by MyEclipse Hibernate Tools.-->
<
hibernate-configuration>
<
session-factory>
<
property name="hbm2ddl.auto">
update<
/property>
<
property name="dialect">
org.hibernate.dialect.Oracle9Dialect<
/property>
<
property name="connection.url">
jdbc:oracle:thin:@localhost:1521:xe<
/property>
<
property name="connection.username">
system<
/property>
<
property name="connection.password">
jtp<
/property>
<
property name="connection.driver_class">
oracle.jdbc.driver.OracleDriver<
/property>
<
mapping resource="question.hbm.xml"/>
<
/session-factory>
<
/hibernate-configuration>
4)创建类来存储数据
在此类中, 我们存储问题类的数据。
package com.srcmini;
import java.util.ArrayList;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.Metadata;
import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
public class StoreData {
public static void main(String[] args) { StandardServiceRegistry ssr=new StandardServiceRegistryBuilder().configure("hibernate.cfg.xml").build();
Metadata meta=new MetadataSources(ssr).getMetadataBuilder().build();
SessionFactory factory=meta.getSessionFactoryBuilder().build();
Session session=factory.openSession();
Transaction t=session.beginTransaction();
Answer ans1=new Answer();
ans1.setAnswername("Java is a programming language");
ans1.setPostedBy("Ravi Malik");
Answer ans2=new Answer();
ans2.setAnswername("Java is a platform");
ans2.setPostedBy("Sudhir Kumar");
Answer ans3=new Answer();
ans3.setAnswername("Servlet is an Interface");
ans3.setPostedBy("Jai Kumar");
Answer ans4=new Answer();
ans4.setAnswername("Servlet is an API");
ans4.setPostedBy("Arun");
ArrayList<
Answer>
list1=new ArrayList<
Answer>
();
list1.add(ans1);
list1.add(ans2);
ArrayList<
Answer>
list2=new ArrayList<
Answer>
();
list2.add(ans3);
list2.add(ans4);
Question question1=new Question();
question1.setQname("What is Java?");
question1.setAnswers(list1);
Question question2=new Question();
question2.setQname("What is Servlet?");
question2.setAnswers(list2);
session.persist(question1);
session.persist(question2);
t.commit();
session.close();
System.out.println("success");
}
}
输出值
文章图片
文章图片
如何获取列表数据
在这里, 我们使用HQL来获取Question类的所有记录, 包括答案。在这种情况下, 它将从两个与功能相关的表中获取数据。在这里, 我们直接打印出答案类的对象, 但是我们已经覆盖了答案类中的toString()方法, 该方法返回了答案名称和发布者名称。因此, 它将打印答案名称和张贴者名称, 而不是参考ID。
FetchData.java
package com.srcmini;
import java.util.*;
import javax.persistence.TypedQuery;
import org.hibernate.*;
import org.hibernate.boot.Metadata;
import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
public class FetchData {
public static void main(String[] args) { StandardServiceRegistry ssr=new StandardServiceRegistryBuilder().configure("hibernate.cfg.xml").build();
Metadata meta=new MetadataSources(ssr).getMetadataBuilder().build();
SessionFactory factory=meta.getSessionFactoryBuilder().build();
Session session=factory.openSession();
TypedQuery query=session.createQuery("from Question");
List<
Question>
list=query.getResultList();
Iterator<
Question>
itr=list.iterator();
while(itr.hasNext()){
Question q=itr.next();
System.out.println("Question Name: "+q.getQname());
//printing answers
List<
Answer>
list2=q.getAnswers();
Iterator<
Answer>
itr2=list2.iterator();
while(itr2.hasNext())
{
Answer a=itr2.next();
System.out.println(a.getAnswername()+":"+a.getPostedBy());
}
}
session.close();
System.out.println("success");
}
}
输出值
文章图片
推荐阅读
- 使用注解Hibernate一对多示例
- Hibernate命名查询
- 使用XML Hibernate多对一映射
- 使用注解Hibernate多对一映射
- 使用XML的Hibernate多对多示例
- 使用注解Hibernate多对多示例
- Hibernate生命周期
- Hibernate配置
- Hibernate和Struts 2集成