【使用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");
}
}
输出量
文章图片
文章图片
如何获取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 Mapping Map
- 集合映射中的映射列表(使用xml文件)
- 集合映射中的映射包(使用xml文件)
- Hibernate惰性集合
- JPA与Hibernate的区别
- Hibernate查询语言(HQL)
- Hibernate事务管理示例
- 使用注解的每个子类的表
- 使用注解的实体表类