本文概述
- 1)一对一映射的持久类
- 2)持久类的映射文件
- 3)配置文件
- 4)用于存储和获取数据的用户类
在此示例中, 每个员工只有一个公司地址, 而一个地址属于许多员工。在这里, 我们将使用XML执行多对一映射。
1)一对一映射的持久类 有两个持久性类Employee.java和Address.java。雇员类包含地址类引用, 反之亦然。
Employee.java
package com.srcmini;
public class Employee {
private int employeeId;
private String name, email;
private Address address;
//setters and getters
}
Address.java
package com.srcmini;
public class Address {
private int addressId;
private String addressLine1, city, state, country;
private int pincode;
private Employee employee;
//setters and getters
}
2)持久类的映射文件 这两个映射文件是employee.hbm.xml和address.hbm.xml。
employee.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.Employee" table="emp22">
<
id name="employeeId">
<
generator class="increment">
<
/generator>
<
/id>
<
property name="name">
<
/property>
<
property name="email">
<
/property>
<
many-to-one name="address" cascade="all">
<
/many-to-one>
<
/class>
<
/hibernate-mapping>
address.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.Address" table="address22">
<
id name="addressId">
<
generator class="increment">
<
/generator>
<
/id>
<
property name="addressLine1">
<
/property>
<
property name="city">
<
/property>
<
property name="state">
<
/property>
<
property name="country">
<
/property>
<
property name="pincode">
<
/property>
<
/class>
<
/hibernate-mapping>
3)配置文件 【使用XML Hibernate多对一映射】该文件包含有关数据库和映射文件的信息。
<
?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="employee.hbm.xml"/>
<
mapping resource="address.hbm.xml"/>
<
/session-factory>
<
/hibernate-configuration>
4)用于存储和获取数据的用户类 Store.java
package com.srcmini;
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 Store {
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();
Employee e1=new Employee();
e1.setName("Ravi Malik");
e1.setEmail("ravi@gmail.com");
Employee e2=new Employee();
e2.setName("Anuj Verma");
e2.setEmail("anuj@gmail.com");
Address address1=new Address();
address1.setAddressLine1("G-13, Sector 3");
address1.setCity("Noida");
address1.setState("UP");
address1.setCountry("India");
address1.setPincode(201301);
e1.setAddress(address1);
e2.setAddress(address1);
session.persist(e1);
session.persist(e2);
t.commit();
session.close();
System.out.println("success");
}
}
输出量
文章图片
文章图片
Fetch.java
package com.srcmini;
import java.util.Iterator;
import java.util.List;
import javax.persistence.TypedQuery;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.boot.Metadata;
import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
public class Fetch {
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 Employee e");
List<
Employee>
list=query.getResultList();
Iterator<
Employee>
itr=list.iterator();
while(itr.hasNext()){
Employee emp=itr.next();
System.out.println(emp.getEmployeeId()+" "+emp.getName()+" "+emp.getEmail());
Address address=emp.getAddress();
System.out.println(address.getAddressLine1()+" "+address.getCity()+" "+
address.getState()+" "+address.getCountry()+" "+address.getPincode());
}session.close();
System.out.println("success");
}
}
输出量
文章图片
下载
推荐阅读
- Hibernate命名查询
- 使用注解Hibernate多对一映射
- 使用XML的Hibernate多对多示例
- 使用注解Hibernate多对多示例
- Hibernate生命周期
- Hibernate配置
- Hibernate和Struts 2集成
- Hibernate和Spring集成
- HCQL(Hibernate标准查询语言)