一对一的另一种解决方式就是主键关联,在这种关联关系中,要求两个对象的主键必须保持一致,通过两个表的主键建立关联关系须外键参与。 没法传图 我就用这个表示吧 看id

Copany         Address

 id<Pk>          id<Pk><Fk>

 name              home

基于主键的映射策略:指一端的主键生成器使用 foreign 策略,表明根据”对方”的主键来生成自己的主键,自己并不能独立生成主键. <param> 子元素指定使用当前持久化类的哪个属性作为 “对方”

<generator class="foreign">
<param name="property">idcharbean</param>
</generator>

采用foreign主键生成器策略的一端增加 one-to-one 元素映射关联属性,其 one-to-one 属性还应增加 constrained=“true” 属性;另一端(company)增加one-to-one元素映射关联属性。

constrained(约束):指定为当前持久化类对应的数据库表的主键添加一个外键约束,引用被关联的对象(“对方”)所对应的数据库表主键

    <one-to-one name="idcharbean" class="Idcharbean" constrained="true"></one-to-one>
   

无有外键方(Idcharbean)配置 bean:

  

package com.java.bean;

public class Idcharbean  {
private int id;
private int nameber;
private Person person; public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public int getNameber() {
return nameber;
} public void setNameber(int nameber) {
this.nameber = nameber;
} public Person getPerson() {
return person;
} public void setPerson(Person person) {
this.person = person;
}
}

hm.xml 配置

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.java.bean">
<class name="Idcharbean" table="t_idcahr">
<id name="id" type="int" column="id">
<generator class="identity"/> <!--这个地方的配置是一对一的关键哟-->
</id>
<property name="nameber" type="int" column="nameber" length="20"/>
<one-to-one name="person" class="Person"></one-to-one>
</class>
</hibernate-mapping>

有外键方(Person)配置 bean

  

package com.java.bean;

public class Person  {
private int id;
private String name;
private Idcharbean idcharbean; public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public Idcharbean getIdcharbean() {
return idcharbean;
} public void setIdcharbean(Idcharbean idcharbean) {
this.idcharbean = idcharbean;
}
}

hbm.xml配置

  

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.java.bean">
<class name="Person" table="t_person">
<id name="id" type="int" column="id">
<generator class="foreign">
<param name="property">idcharbean</param> <!--这个就是共同主键-->
</generator>
</id>
<property name="name" type="string" column="name" length="20"/>
<one-to-one name="idcharbean" class="Idcharbean" constrained="true"></one-to-one>
</class>
</hibernate-mapping>

关于 foregin:表示主键策略使用foreign

*表示根据对方主键生成自己的主键

*param子元素指定使用前持久化

关于 constrained="true"
*指定为当前持久化类的对应表的主键添加外键约束 应用被关联的对象 "对方"所对应的数据库表主键 配置完成后写个增加 玩一下
  
public class Idchardao {
private static SessionFactory sf;
static {
try {
Configuration configuration = new Configuration();
configuration.configure();
ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(configuration.getProperties()).buildServiceRegistry();
sf = configuration.buildSessionFactory(serviceRegistry);
}catch (Exception e){
throw e;
}
}
public void add(Idcharbean idcharbean){
Session s = sf.openSession();
Transaction t =null;
try {
t = s.beginTransaction();
s.save(idcharbean);
t.commit();
}catch (Exception e){
t.rollback();
}finally {
s.close();
}
}
}

ps需要两个类dao里都有add哟

然后是test文件 添加一下

@Test
public void testAdd() throws Exception {
Idcharbean idcharbean = new Idcharbean();
idcharbean.setNameber(1111);
Person person = new Person();
person.setName("马虎"); idcharbean.setPerson(person);
person.setIdcharbean(idcharbean); new Idchardao().add(idcharbean);
new Psersondao().add(person); }

然后再写个  获取id可以获取到关联的对方id的小测试文件

  

public Idcharbean Get(){
Session s = sf.openSession();
Transaction t = null;
Idcharbean idcharbean = null;
try {
t = s.beginTransaction();
idcharbean = (Idcharbean) s.get(Idcharbean.class,1);
t.commit();
}catch (Exception e){
t.rollback();
}finally {
s.close();
}
return idcharbean;
}

不如在搞个 移除关系 说动手就动手

  

  //解除关系
public void Remove() {
Session s = sf.openSession();
Transaction t = null;
try {
t = s.beginTransaction();
Person person = (Person) s.get(Person.class, 1);
person.setIdcharbean(null);
t.commit();
} catch (Exception e) {
t.rollback();
} finally {
s.close();
} }

既然都移除了不如再来个删除玩玩

  

          //删除
public void delet(){
Session s = sf.openSession();
Transaction t = null;
try {
t = s.beginTransaction();
Person person = (Person) s.get(Person.class,1); s.delete(person);
/* Idcharbean idcharbean = (Idcharbean) s.get(Idcharbean.class,1);
s.delete(idcharbean);*/
t.commit();
}catch (Exception e){
t.rollback();
}finally {
s.close();
}
}
哟 写完了 更多的方法 我在多对多中搞吧= = 话说为啥 我多对多还没写就写一对一了 我是不是疯了

hibernate 一对一关系的更多相关文章

  1. hibernate(五) hibernate一对一关系映射详解

    序言 之前讲解了一对多(单向.双向).多对多(双向),今天就讲解一下最后一个关系,一对一. 心情不错.状态也挺好的,赶紧写一篇博文造福一下大家把. --WH 一.一对一关系的概述 一对一关系看起来简单 ...

  2. Hibernate学习(五)———— hibernate一对一关系映射详解

    一.一对一关系的概述 一对一关系看起来简单,其实也挺复杂的.其中关系就包含了四种,单向双向和主键关联外键关联. 什么意思呢,也就是包含了单向一对一主键关联.双向一对一主键关联,单向一对一外键关联,双向 ...

  3. Hibernate一对一关系映射

    Hibernate提供了两种一对一映射关联关系的方式: 1)按照外键映射 2)按照主键映射 下面以员工账号表和员工档案表(员工账号和档案表之间是一对一的关系)为例,介绍这两种映射关系,并使用这两种 映 ...

  4. hibernate一对一关系实现

    按照主键映射,按照外键映射 Address.hbm.xml: <?xml version="1.0"?><!DOCTYPE hibernate-mapping P ...

  5. hibernate对象关系实现(二)一对一

    双向一对一以部门和经理为例: a.部门和经理类中各自由对方的引用:(省略了get/set方法) b.数据库两种方式实现:一种(b.1)是外键映射,并将外键添加唯一约束(至于哪个对象的主键做外键,可随意 ...

  6. Hibernate中的一对一关系详解(1)

    A:先讲讲一对一的关系(欲知其他关系,请看下篇) a:主键关联的一对一关系 一对一关系一般用主键关联,也就是说用主键值来维护两者的关系,一个表的主键存放另一个表的主键值.例如在员工与帐号中,我们取员工 ...

  7. Hibernate 集合映射 一对多多对一 inverse属性 + cascade级联属性 多对多 一对一 关系映射

    1 . 集合映射 需求:购物商城,用户有多个地址. // javabean设计 // javabean设计 public class User { private int userId; privat ...

  8. Hibernate One-to-One Mappings 一对一关系映射

    Hibernate One-to-One Mappings 一对一关系映射 关键:一对一关系映射和多对一关系映射非常像.仅仅是unique 属性值为 true 样例:一个员工仅仅能有一个地址. Hib ...

  9. Hibernate学习8—Hibernate 映射关系(一对一)

    第一节:Hibernate 一对一映射关系实现 假设一个用户对应一个地址:   1)按照主键映射: User.java: package com.cy.model; public class User ...

随机推荐

  1. 第15章-输入/输出 --- File类

    (一) Java的IO通过java.io包下的类和接口来支持,在java.io包下主要包括输入.输出两种IO流. 每种输入.输出流又分为字节流和字符流两大类: (1)字节流以字节为单位来处理输入.输出 ...

  2. java死锁小例子

    package cn.com.io.threadDemo.ThreadSyn; /** * 通过两个属性值创建死锁 * 本程序通过两个线程各自锁定一个属性值,这样两个线程都无法结束,造成死锁 * @a ...

  3. 使用commons-compress操作zip文件(压缩和解压缩)

    http://www.cnblogs.com/luxh/archive/2012/06/28/2568758.html Apache Commons Compress是一个压缩.解压缩文件的类库. 可 ...

  4. Android 源码中的设计模式

    最近看了一些android的源码,发现设计模式无处不在啊!感觉有点乱,于是决定要把设计模式好好梳理一下,于是有了这篇文章. 面向对象的六大原则 单一职责原则 所谓职责是指类变化的原因.如果一个类有多于 ...

  5. 【已解决】C#中往SQLServer插入数据时遇到BUG

    错误信息如下: “System.Data.SqlClient.SqlException”类型的未经处理的异常在 System.Data.dll 中发生 其他信息: “”附近有语法错误. 文字版代码如下 ...

  6. URI和URL的区别 【转】

    源地址:http://www.cnblogs.com/gaojing/archive/2012/02/04/2413626.html 这两天在写代码的时候,由于涉及到资源的位置,因此,需要在Java ...

  7. JS入门熟知

    JS是面向对象的语言 封装 继承 多态 聚集(对象中具有引用其他对象的能力) JS使用中绝大多数情况不需要进行面向对象的设计,很多情况是使用已经设计好,准备好的对象,基于对象的语言. JS的使用(引入 ...

  8. 关于C#中程序功能实现,对代码选择的思考

    body { background-color: rgb(60,60,60) } 接触C#语言只有短短几天时间,想要写出什么高大上的深入性研究文章,估计也是满篇的猜想和一些没有逻辑的推断.截至目前而言 ...

  9. 定制炫彩界面:duilib与MFC 的对比

    duilib是以DirectUI为技术原理开发的一款轻量级Windows桌面UI库,使用XML来描述界面风格,界面布局,可以很方便的构建高效,绚丽的,非常易于扩展的界面.从而很好的将界面和逻辑分离,同 ...

  10. HTML结构及基础语法

    一.HTML结构 <!DOCTYPE html><html lang="en"><head> <meta charset="UT ...