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

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

输出量

Hibernate映射集示例1
Hibernate映射集示例2

如何获取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");  
      
}  
}

输出量

Hibernate映射集示例3

下载

赞(0)
未经允许不得转载:srcmini » 使用XML的Hibernate映射集

评论 抢沙发

评论前必须登录!