📅  最后修改于: 2021-01-02 15:36:00             🧑  作者: Mango
如果我们的持久类具有List对象,则可以在映射文件中按列表或bag元素映射List。包就像List一样,但是不需要index元素。
在这里,我们使用的是论坛的场景,其中一个问题有多个答案。
让我们看看如何在映射文件中实现bag:
...
...
在此示例中,我们将按包查看集合映射的完整示例。这是bag的示例,如果它存储值而不是实体引用,这就是为什么要使用element而不是一对多的原因。如果您已经看到了映射列表的示例,则在所有情况下都是相同的,但是在我们使用bag而不是list的情况下,映射文件是相同的。
该持久类定义了包括List在内的类的属性。
package com.javatpoint;
import java.util.List;
public class Question {
private int id;
private String qname;
private List answers;
//getters and setters
}
在这里,我们创建了用来定义列表的question.hbm.xml文件。
该文件包含有关数据库和映射文件的信息。
update
org.hibernate.dialect.Oracle9Dialect
jdbc:oracle:thin:@localhost:1521:xe
system
jtp
oracle.jdbc.driver.OracleDriver
在此类中,我们存储问题类别的数据。
package com.javatpoint;
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.buildSessionFactory();
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.buildSessionFactory();
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");
}
}