个性化阅读
专注于IT技术分析

使用XML的Hibernate一对多示例

点击下载

如果持久性类的列表对象包含实体引用, 则需要使用一对多关联来映射列表元素。

在这里, 我们使用的是论坛的场景, 其中一个问题有多个答案。

Hibernate按列表进行一对多映射

在这种情况下, 一个问题可能有很多答案, 每个答案可能都有自己的信息, 这就是为什么我们在持久性类(包含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

}

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");  
}  
}

输出值

一对多Hibernate示例1
一对多Hibernate示例1

如何获取列表数据

在这里, 我们使用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一对多示例3
赞(0)
未经允许不得转载:srcmini » 使用XML的Hibernate一对多示例

评论 抢沙发

评论前必须登录!