使用XML的Hibernate映射集

【使用XML的Hibernate映射集】如果持久类具有Set对象, 则可以在映射文件中映射Set by set元素。 set元素不需要index元素。 List和Set之间的区别是它仅存储唯一值。
让我们看看如何在映射文件中实现集合:

< class name="com.srcmini.Question" table="q1002"> ... < set name="answers" table="ans1002"> < key column="qid"> < /key> < element column="answer" type="string"> < /element> < /set> ... < /class>

集合映射中的映射集示例
在此示例中, 我们将按集合查看集合映射的完整示例。这是存储值而不是实体引用的set的示例, 这就是为什么要使用element而不是一对多的原因。
1)创建持久性类
该持久类定义了包含Set的类的属性。
package com.srcmini; import java.util.Set; public class Question { private int id; private String qname; private Set< String> answers; //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="q1002"> < id name="id"> < generator class="increment"> < /generator> < /id> < property name="qname"> < /property> < set name="answers" table="ans1002"> < key column="qid"> < /key> < element column="answer" type="string"> < /element> < /set> < /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"> < 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.HashSet; 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 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(); HashSet< String> set1=new HashSet< String> (); set1.add("Java is a programming language"); set1.add("Java is a platform"); HashSet< String> set2=new HashSet< String> (); set2.add("Servlet is an Interface"); set2.add("Servlet is an API"); Question question1=new Question(); question1.setQname("What is Java?"); question1.setAnswers(set1); Question question2=new Question(); question2.setQname("What is Servlet?"); question2.setAnswers(set2); session.persist(question1); session.persist(question2); t.commit(); session.close(); System.out.println("success"); } }

输出量
使用XML的Hibernate映射集

文章图片
使用XML的Hibernate映射集

文章图片
如何获取Set的数据
在这里, 我们使用HQL来获取Question类的所有记录, 包括答案。在这种情况下, 它将从两个功能相关的表中获取数据。
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(); Transaction t=session.beginTransaction(); 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 Set< String> set=q.getAnswers(); Iterator< String> itr2=set.iterator(); while(itr2.hasNext()){ System.out.println(itr2.next()); }} session.close(); System.out.println("success"); } }

输出量
使用XML的Hibernate映射集

文章图片
下载

    推荐阅读