一对一的另一种解决方式就是主键关联,在这种关联关系中,要求两个对象的主键必须保持一致,通过两个表的主键建立关联关系须外键参与。 没法传图 我就用这个表示吧 看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. JMM规范

    JMM规范: The rules for happens-before are: Program order rule. Each action in a thread happens-before ...

  2. YUV420格式解析

    一般的的YUV420图像格式实际上是Y'UV,420指的是其在Y U V上面的采样率.在YUV420的格式中,首先存储每一个像素的Y'值,然后跟着存储的是每2*2方阵采样一次的U值,最后存储的是每2* ...

  3. 记住这个网站:服务器相关数据统计网站 http://news.netcraft.com/

    http://news.netcraft.com/ 需要参考现在服务器相关数据,可以上这个网站. 当然google趋势也是一个可选得备案. 有一个数据统计更全面的: http://w3techs.co ...

  4. java-将评论内容过滤特殊表情emoj符号,保存到mysql中

    正常操作评论,保存时,若评论内容含有特殊表情符号,后台将报错如下: Illegal mix of collations (utf8_general_ci,IMPLICIT) and (utf8mb4_ ...

  5. HTML学习笔记 day two

    HTML学习笔记 day two Charter three网站中的文本样式标签 3.1设置标题字体 语法结构:<h#>标题文字</h#> 注:其中的#可以为1,2,3,4,5 ...

  6. 初探Margin负值(转)

    相对而言,margin 负值的使用机率在布局中似乎很少,但是我相信一旦你开始掌握就会着迷,接下来我们看看关于margin负值的一些资料: 它是一个有效的属性,至少w3c中明确描述如下:”Negativ ...

  7. 40多行python代码开发一个区块链。

    40多行python代码开发一个区块链?可信吗?我们将通过Python 2动手开发实现一个迷你区块链来帮你真正理解区块链技术的核心原理.python开发区块链的源代码保存在Github. 尽管有人认为 ...

  8. jq slideToggle()坑

    jQuery slideToggle() 方法 jQuery slideToggle() 方法可以在 slideDown() 与 slideUp() 方法之间进行切换. 如果元素向下滑动,则 slid ...

  9. 怎么确定Oracle客户端安装成功

    可通过能否登录sqlplus来判断是否安装成功. 操作系统:windows10 oracle版本:oracle 11g 步骤: 1.电脑win键+R键,输入cmd,进入命令提示符. 2.命令行中输入: ...

  10. Boyer-Moore(BM)算法,文本查找,字符串匹配问题

    KMP算法的时间复杂度是O(m + n),而Boyer-Moore算法的时间复杂度是O(n/m).文本查找中“ctrl + f”一般就是采用的BM算法. Boyer-Moore算法的关键点: 从右遍历 ...