本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用

内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系。

本人互联网技术爱好者,互联网技术发烧友

微博:伊直都在0221

QQ:951226918

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

1.映射一对一关联关系

  1)域模型

      

  2)关系数据模型:

    

2.基于外键映射的 1-1

  1)对于基于外键的1-1关联,其外键可以存放在任意一边,在需要存放外键一端,增加many-to-one元素。为many-to-one元素增加unique=“true” 属性来表示为1-1关联

  <!-- 使用 many-to-one 的方式来映射 1-1 关联关系 -->
<many-to-one name="mgr" class="Manager">
<column name="MGR_ID" unique="true"></column>
</many-to-one>

   2)另一端需要使用one-to-one元素,该元素使用 property-ref 属性指定使用被关联实体主键以外的字段作为关联字段

  <!-- 映射 1-1 的关联关系:在对应的数据表中已经有外键了,当前持久化类使用 one-to-one 进行映射
需要使用one-to-one元素,该元素使用 property-ref 属性指定使用被关联实体主键以外的字段作为关联字段
-->
<one-to-one name="dept" class="Department" property-ref="mgr"></one-to-one>

  

  

Manager
 package com.jason.hibernate.entities.foreign.one2one;

 public class Manager {

     private Integer mgrId;
private String mgrName;
private Department dept;

public Integer getMgrId() {
return mgrId;
} public void setMgrId(Integer mgrId) {
this.mgrId = mgrId;
} public String getMgrName() {
return mgrName;
} public void setMgrName(String mgrName) {
this.mgrName = mgrName;
} public Department getDept() {
return dept;
} public void setDept(Department dept) {
this.dept = dept;
} }
Department 
 package com.jason.hibernate.entities.foreign.one2one;

 public class Department {
private Integer deptId;
private String deptName; private Manager mgr;

public Integer getDeptId() {
return deptId;
} public void setDeptId(Integer deptId) {
this.deptId = deptId;
} public String getDeptName() {
return deptName;
} public void setDeptName(String deptName) {
this.deptName = deptName;
} public Manager getMgr() {
return mgr;
} public void setMgr(Manager mgr) {
this.mgr = mgr;
} }

Department.hbm.xml

 <?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2016-10-5 22:31:35 by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping package="com.jason.hibernate.entities.foreign.one2one">
<class name="Department" table="DEPARTMENT"> <id name="deptId" type="java.lang.Integer">
<column name="DEPT_ID" />
<generator class="native" />
</id> <property name="deptName" type="java.lang.String">
<column name="DEPT_NAME" />
</property> <!-- 使用 many-to-one 的方式来映射 1-1 关联关系 -->
<many-to-one name="mgr" class="Manager">
<column name="MGR_ID" unique="true"></column>
</many-to-one> </class> </hibernate-mapping>

Manager.hbm.xml

 <?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2016-10-5 22:31:35 by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping package="com.jason.hibernate.entities.foreign.one2one">
<class name="Manager" table="MANAGER"> <id name="mgrId" type="java.lang.Integer">
<column name="MGR_ID" />
<generator class="native" />
</id> <property name="mgrName" type="java.lang.String">
<column name="MGR_NAME" />
</property> <!-- 映射 1-1 的关联关系:在对应的数据表中已经有外键了,当前持久化类使用 one-to-one 进行映射
需要使用one-to-one元素,该元素使用 property-ref 属性指定使用被关联实体主键以外的字段作为关联字段
-->
<one-to-one name="dept" class="Department" property-ref="mgr"></one-to-one>
</class> </hibernate-mapping>

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">
<hibernate-configuration>
<session-factory>
<!-- hibernate 连接数据库的基本信息 -->
<property name="connection.username">root</property>
<property name="connection.password">zhangzhen</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql:///hibernate</property> <!-- 配置hibernate 的节本信息 -->
<!-- hibernate 所使用的数据库方言 -->
<!--<property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property>-->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 执行操作时是否在控制台打印SQL -->
<property name="show_sql">true</property> <!-- 是否都SQL 进行格式化 -->
<property name="format_sql">true</property> <!-- 指定自动生成数据表的策略 -->
<property name="hbm2ddl.auto">update</property> <!-- 设置hibernate 的事务隔离级别 -->
<property name="connection.isolation">2</property> <!-- 配置c3p0 -->
<property name="hibernate.c3p0.max_size">10</property>
<property name="hibernate.c3p0.min_size">5</property>
<property name="c3p0.acquire_increment">2</property>
<property name="c3p0.idle_test_period">2000</property>
<property name="c3p0.timeout">2000</property>
<property name="c3p0.max_statements">10</property>
<!-- 1-1 映射 --> <mapping resource="com/jason/hibernate/entities/foreign/one2one/Manager.hbm.xml"/>
<mapping resource="com/jason/hibernate/entities/foreign/one2one/Department.hbm.xml"/> </session-factory> </hibernate-configuration>

HibernateTest

 package com.jason.hibernate.entities.foreign.one2one;

 import hibernate.helloworld.News;

 import java.util.Date;

 import org.hibernate.Hibernate;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.service.ServiceRegistryBuilder;
import org.junit.After;
import org.junit.Before;
import org.junit.Test; public class HibernateTest { private SessionFactory sessionFactory;
private Session session;
private Transaction transaction;
@Test
public void test() { // 1. 创建一个SessionFatory 对象
SessionFactory sessionFactory = null; // 1) 创建Configuration 对象:对应hibernate 的基本配置信息 和 对象关系映射信息
Configuration configuration = new Configuration().configure(); // 2) 创建一个ServiceRegistry 对象:hibernate 4.x 新天添加的对象。
// hibernate 的任何配置 和 服务都需要在该对象中注册后才有效
ServiceRegistry serviceRegistry = new ServiceRegistryBuilder()
.applySettings(configuration.getProperties())
.buildServiceRegistry(); // sessionFactory = configuration.buildSessionFactory();
sessionFactory = configuration.buildSessionFactory(serviceRegistry); // 2. 创建一个session 对象
Session session = sessionFactory.openSession(); // 3. 开启事物
Transaction transaction = session.beginTransaction(); // 4.执行保存操作
News news = new News("java", "jason", new Date(
new java.util.Date().getTime()));
session.save(news); // 5.提交事物
transaction.commit();
// 6.关闭session
session.close();
// 7.关闭SessionFactory 对象
sessionFactory.close();
} // 创建上述三个对象
@Before
public void init() {
Configuration configuration = new Configuration().configure();
ServiceRegistry serviceRegistry = new ServiceRegistryBuilder()
.applySettings(configuration.getProperties())
.buildServiceRegistry(); sessionFactory = configuration.buildSessionFactory(serviceRegistry); session = sessionFactory.openSession(); transaction = session.beginTransaction();
} // 关闭上述三个对象
@After
public void destroy() {
transaction.commit();
session.close();
sessionFactory.close();
} @Test
public void testSave(){ Department department = new Department();
department.setDeptName("DEPT-AA"); Manager manager = new Manager();
manager.setMgrName("MGR-AA"); //设定关联关系
department.setMgr(manager);
manager.setDept(department); //保存
//建议先保存没有外键列的那个对象,这样会减少update 语句
session.save(manager);
session.save(department); } @Test
public void testGet(){ //1.默认情况下对关联属性使用懒加载
Department dept = (Department) session.get(Department.class, 1);
System.out.println(dept.getDeptName()); //2.查询Manager 对象的连接条件应该是dept.manager_id = mgr.manager_id
//而不因该是 manager0_.MGR_ID=department1_.DEPT_ID
Manager mgr = dept.getMgr();
System.out.println(mgr);
} @Test
public void testGet2(){ //在查询没有外键的实体对象,使用的是左外连接查询,一并查询出其关联的对象,并已经进行初始化
Manager manager = (Manager) session.get(Manager.class, 1);
System.out.println(manager); System.out.println(manager.getDept().getDeptName()); } }

最新文章

  1. YII2之&#160;Scenario
  2. SQL注入:突破关键字过滤
  3. 翻滚吧,Spark (错误记录)
  4. 解决HtmlAgilityPack无法获取form标签子节点的问题
  5. iOS - OC NSNull 空值
  6. 第三百零七天 how can I 坚持
  7. oracle 表空间常用语句
  8. 简单工厂模式的C++实现
  9. Erasure Coding in WAS简单译文
  10. input的type属性引申的日历组件
  11. windows 10 下使用 binwalk
  12. POJ-3522 Slim Span(最小生成树)
  13. php微信扫码支付
  14. android 检查软件是否有更新版本
  15. truncate、delete、drop区别
  16. Django Rest Framework-介绍
  17. 7、Python-引用传递与值传递
  18. MySQL复制的管理和维护
  19. MongoDB安装、CURD操作、使用场景分析总结(1)
  20. iis7中session丢失的解决方法小结

热门文章

  1. Delphi 如何清除动态数组的内存?
  2. 深入了解php opcode缓存原理
  3. pro10
  4. postgressql安装
  5. Div自适应高度的方法
  6. zepto源码--isEmptyObject,isNumeric,inArray,trim--学习笔记
  7. Cocos2d-JS目录说明
  8. 20145211 《Java程序设计》第7周学习总结——沧海横流
  9. 【python】numpy array特殊数据统一处理
  10. magento多语言中文语言包