使用XML的Hibernate一对多示例

如果持久性类的列表对象包含实体引用, 则需要使用一对多关联来映射列表元素。
在这里, 我们使用的是论坛的场景, 其中一个问题有多个答案。

使用XML的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}

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

输出值
使用XML的Hibernate一对多示例

文章图片
使用XML的Hibernate一对多示例

文章图片
如何获取列表数据
在这里, 我们使用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"); } }

输出值
使用XML的Hibernate一对多示例

文章图片

    推荐阅读