正如我们在前面的例子中讨论过的,在hibernate中执行一对一映射有两种方法:

  • 通过many-to-one元素
  • 通过one-to-one元素

这里,我们将通过one-to-one元素进行一对一的映射。 在这种情况下,不会在主表中创建外键。

在这个例子中,一个员工只能有一个地址,一个地址只能属于一个员工。 在这里使用双向关联。我们来看看持久化类。

1)一对一映射的持久类

有两个持久化类Employee.javaAddress.java。 Employee类包含Address类引用,反之亦然。

创建一个名称为:onetooneprimary 的java项目,其项目文件目录结构如下 -

文件:Employee.java

package com.yiibai;

public class Employee {
private int employeeId;
private String name, email; private Address address; public int getEmployeeId() {
return employeeId;
} public void setEmployeeId(int employeeId) {
this.employeeId = employeeId;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getEmail() {
return email;
} public void setEmail(String email) {
this.email = email;
} public Address getAddress() {
return address;
} public void setAddress(Address address) {
this.address = address;
} }
Java

文件:Address.java

package com.yiibai;

public class Address {
private int addressId;
private String addressLine1, city, state, country;
private int pincode;
private Employee employee; public int getAddressId() {
return addressId;
} public void setAddressId(int addressId) {
this.addressId = addressId;
} public String getAddressLine1() {
return addressLine1;
} public void setAddressLine1(String addressLine1) {
this.addressLine1 = addressLine1;
} public String getCity() {
return city;
} public void setCity(String city) {
this.city = city;
} public String getState() {
return state;
} public void setState(String state) {
this.state = state;
} public String getCountry() {
return country;
} public void setCountry(String country) {
this.country = country;
} public int getPincode() {
return pincode;
} public void setPincode(int pincode) {
this.pincode = pincode;
} public Employee getEmployee() {
return employee;
} public void setEmployee(Employee employee) {
this.employee = employee;
} }
Java

2)持久化类映射文件

两个映射文件分别是:employee.hbm.xmladdress.hbm.xml

文件:employee.hbm.xml

在这个映射文件中,我们在映射文件中使用one-to-one元素进行一对一映射。

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping>
<class name="com.yiibai.Employee" table="emp_2120">
<id name="employeeId">
<generator class="increment"></generator>
</id>
<property name="name"></property>
<property name="email"></property> <one-to-one name="address" cascade="all"></one-to-one>
</class> </hibernate-mapping>
XML

文件:address.hbm.xml

这是Address类的简单映射文件。 但重要的是生成器(generator)类。 在这里,我们正在使用依赖于Employee类主键的外部generator类。

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping>
<class name="com.yiibai.Address" table="address_2120">
<id name="addressId">
<generator class="foreign">
<param name="property">employee</param>
</generator>
</id>
<property name="addressLine1"></property>
<property name="city"></property>
<property name="state"></property>
<property name="country"></property> <one-to-one name="employee" cascade="all"></one-to-one>
</class> </hibernate-mapping>
XML

3)配置文件

此文件包含有关数据库和映射文件的信息。
文件:hibernate.cfg.xml

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration> <session-factory>
<property name="hbm2ddl.auto">update</property> <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/test</property>
<property name="connection.username">root</property>
<property name="connection.password">123456</property>
<property name="dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
<property name="show_sql">true</property> <mapping resource="employee.hbm.xml" />
<mapping resource="address.hbm.xml" />
</session-factory> </hibernate-configuration>
XML

4)存储和获取数据的用户类

文件:MainTest.java

package com.yiibai;

import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.*;
import org.hibernate.*; public class MainTest {
public static void main(String[] args) {
// 在5.1.0版本汇总,hibernate则采用如下新方式获取:
// 1. 配置类型安全的准服务注册类,这是当前应用的单例对象,不作修改,所以声明为final
// 在configure("cfg/hibernate.cfg.xml")方法中,如果不指定资源路径,默认在类路径下寻找名为hibernate.cfg.xml的文件
final StandardServiceRegistry registry = new StandardServiceRegistryBuilder()
.configure("hibernate.cfg.xml").build();
// 2. 根据服务注册类创建一个元数据资源集,同时构建元数据并生成应用一般唯一的的session工厂
SessionFactory sessionFactory = new MetadataSources(registry)
.buildMetadata().buildSessionFactory(); /**** 上面是配置准备,下面开始我们的数据库操作 ******/
Session session = sessionFactory.openSession();// 从会话工厂获取一个session
// creating transaction object
Transaction t = session.beginTransaction(); Employee e1 = new Employee();
e1.setName("苏小明");
e1.setEmail("xima.su@gmail.com"); Address address1 = new Address();
address1.setAddressLine1("G-1621, Renmin Road");
address1.setCity("海口");
address1.setState("海南");
address1.setCountry("中国");
address1.setPincode(572201); e1.setAddress(address1);
address1.setEmployee(e1); session.persist(e1);
t.commit(); session.close();
System.out.println("success");
}
}
Java

文件:FetchTest.java

package com.yiibai;

import java.util.Iterator;
import java.util.List;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration; public class FetchTest {
public static void main(String[] args) {
// 在5.1.0版本汇总,hibernate则采用如下新方式获取:
// 1. 配置类型安全的准服务注册类,这是当前应用的单例对象,不作修改,所以声明为final
// 在configure("cfg/hibernate.cfg.xml")方法中,如果不指定资源路径,默认在类路径下寻找名为hibernate.cfg.xml的文件
final StandardServiceRegistry registry = new StandardServiceRegistryBuilder()
.configure("hibernate.cfg.xml").build();
// 2. 根据服务注册类创建一个元数据资源集,同时构建元数据并生成应用一般唯一的的session工厂
SessionFactory sessionFactory = new MetadataSources(registry)
.buildMetadata().buildSessionFactory(); /**** 上面是配置准备,下面开始我们的数据库操作 ******/
Session session = sessionFactory.openSession();// 从会话工厂获取一个session
// creating transaction object
Transaction t = session.beginTransaction(); Query query = session.createQuery("from Employee e");
List<Employee> list = query.list(); 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());
} session.close();
System.out.println("success");
}
}
Java

5) 运行示例

首先运行 MainTest.java 来创建表并向表中插入一些数据,然后运行FetchTest.java来读取上面插入的数据信息。

运行 MainTest.java 得到的结果如下-

log4j:WARN No appenders could be found for logger (org.jboss.logging).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
Tue Mar 28 21:07:32 CST 2017 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.
Hibernate: select max(employeeId) from emp_2120
Hibernate: insert into emp_2120 (name, email, employeeId) values (?, ?, ?)
Hibernate: insert into address_2120 (addressLine1, city, state, country, addressId) values (?, ?, ?, ?, ?)
success

运行 FetchTest.java 得到的结果如下-

log4j:WARN No appenders could be found for logger (org.jboss.logging).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
Tue Mar 28 21:07:57 CST 2017 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.
Hibernate: select employee0_.employeeId as employee1_1_, employee0_.name as name2_1_, employee0_.email as email3_1_ from emp_2120 employee0_
Hibernate: select address0_.addressId as addressI1_0_0_, address0_.addressLine1 as addressL2_0_0_, address0_.city as city3_0_0_, address0_.state as state4_0_0_, address0_.country as country5_0_0_, employee1_.employeeId as employee1_1_1_, employee1_.name as name2_1_1_, employee1_.email as email3_1_1_ from address_2120 address0_ left outer join emp_2120 employee1_ on address0_.addressId=employee1_.employeeId where address0_.addressId=?
Hibernate: select address0_.addressId as addressI1_0_0_, address0_.addressLine1 as addressL2_0_0_, address0_.city as city3_0_0_, address0_.state as state4_0_0_, address0_.country as country5_0_0_, employee1_.employeeId as employee1_1_1_, employee1_.name as name2_1_1_, employee1_.email as email3_1_1_ from address_2120 address0_ left outer join emp_2120 employee1_ on address0_.addressId=employee1_.employeeId where address0_.addressId=?
Hibernate: select address0_.addressId as addressI1_0_0_, address0_.addressLine1 as addressL2_0_0_, address0_.city as city3_0_0_, address0_.state as state4_0_0_, address0_.country as country5_0_0_, employee1_.employeeId as employee1_1_1_, employee1_.name as name2_1_1_, employee1_.email as email3_1_1_ from address_2120 address0_ left outer join emp_2120 employee1_ on address0_.addressId=employee1_.employeeId where address0_.addressId=?
1 Yiibai Su yiibai.su@gmail.com
G-1621, Renmin Road Haikou Hainan China
2 苏小明 xima.su@gmail.com
G-1621, Renmin Road 海口 海南 中国
3 苏小明 xima.su@gmail.com
G-1621, Renmin Road 海口 海南 中国
success

最新文章

  1. Oracle 服务手动启动关闭
  2. Mysql索引总结(一)
  3. lstm的debug模式下编译不行貌似
  4. 一个不简单的Procedure body例子
  5. C++中使用union的几点思考(转)
  6. 添加打印机的时候怎样说windows没法连接到打印机毛病为0x00000002
  7. 三种常见字符编码简介:ASCII、Unicode和UTF-8
  8. awk参数详解
  9. HDU2057 A + B Again
  10. JQuery插件开发标准写法
  11. Javascript Sting(字符串)对象
  12. SpringBoot进阶教程(二十七)整合Redis之分布式锁
  13. 前端笔记知识点整合之JavaScript(一)初识JavaScript
  14. 【Maven】---Nexus私服配置Setting和Pom
  15. 高并发秒杀系统--SpringMVC整合
  16. python 管道、数据共享、进程池
  17. 理清cordova插件的调用流程
  18. python3 开发面试题(面向对象)6.6
  19. easy-ui 使用总结
  20. pycharm pro版本激活

热门文章

  1. TSQLDBServerHttpApi一个使用HTTPS.SYS内核的数据库服务端控件
  2. Swift,数组
  3. jquery如何判断元素是否被点击、属性操作、class操作
  4. iOS:使用集成的支付宝SDK的支付流程
  5. js同比例缩放图片
  6. KVO(Key Value Observing)
  7. 【MySQL】海量量数据查询优化
  8. Unity3d-XML文件数据解析&amp;amp;JSON数据解析
  9. 【BIEE】18_时间序列函数的使用
  10. jquery遍历数组的方式