📜  Hibernate教程:集合映射中的映射列表

📅  最后修改于: 2021-01-02 15:35:00             🧑  作者: Mango

集合映射中的映射列表(使用xml文件)

如果我们的持久类具有List对象,则可以通过映射文件中类的元素或通过注释轻松地映射List。

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

让我们看看如何在映射文件中实现列表:



       ...      
          
          
          
          
          
          
       ...


List和Map是基于索引的集合,因此将在表中创建一个额外的列以进行索引。

集合映射中的映射列表示例

在此示例中,我们将按列表查看集合映射的完整示例。这是List的示例,该列表存储字符串值而不是实体引用,这就是为什么我们要在list元素内使用element而不是一对多的原因。

1)创建持久性类

该持久类定义了包括List在内的类的属性。


package com.javatpoint;

import java.util.List;

public class Question {
private int id;
private String qname;
private List answers;

//getters and setters

}

2)为持久化类创建Mapping文件

在这里,我们创建了用来定义列表的question.hbm.xml文件。






 
   
     
   
   
          
   
     
     
     
   
          
 
          


3)创建配置文件

该文件包含有关数据库和映射文件的信息。







    
        update
        org.hibernate.dialect.Oracle9Dialect
        jdbc:oracle:thin:@localhost:1521:xe
        system
        jtp
        oracle.jdbc.driver.OracleDriver
    
    



4)创建存储数据的类

在此类中,我们存储问题类别的数据。


package com.javatpoint;  
  
import java.util.ArrayList;  
  
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();  
      
    ArrayList list1=new ArrayList();  
    list1.add("Java is a programming language");  
    list1.add("Java is a platform");  
      
    ArrayList list2=new ArrayList();  
    list2.add("Servlet is an Interface");  
    list2.add("Servlet is an API");  
      
    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类的所有记录,包括答案。在这种情况下,它将从两个功能相关的表中获取数据。


package com.javatpoint;  
  
import javax.persistence.TypedQuery;
import java.util.*;
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 list=query.getResultList(); 
      
    Iterator itr=list.iterator();  
    while(itr.hasNext()){  
        Question q=itr.next();  
        System.out.println("Question Name: "+q.getQname());  
          
        //printing answers  
        List list2=q.getAnswers();  
        Iterator itr2=list2.iterator();  
        while(itr2.hasNext()){  
            System.out.println(itr2.next());  
        }        
    }  
    session.close();  
    System.out.println("success");       
}  
}  

输出量

下载