Hibernate -- 一对一映射
一对一关联指两个表之间的记录是一一对应的关系。分为两种:外键关联和主键关联。
(1)外键关联
比如一家公司(Company)和它所在的地址(Address)。在业务逻辑中要求一家公司只有唯一的地址,一个地址也只有一家公司。下图表现为外键关联关系。
元素。为many-to-one元素增加unique=“true”属性来表示为1-1关联,并用name属性来指定关联属性的属性名
示例代码:
Company.java bean对象
public class Company implements java.io.Serializable {
private Integer id;
private String name;
//一家公司对应一个地址
private Address address;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Address getAddress() {
return address;
}
public void setAddress(Address address) {
this.address = address;
}
}
Address.java
public class Address implements java.io.Serializable{
private Integer id;
private String city;
private String country;
//一个地址含有一家公司
private Company company;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getCity() {
return city;
}
public void setCity(String city) {
this.city = city;
}
public String getCountry() {
return country;
}
public void setCountry(String country) {
this.country = country;
}
public Company getCompany() {
return company;
}
public void setCompany(Company company) {
this.company = company;
}
}
Company.hbm.xml 映射配置文件
<?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="cn.itcast.one2onefk.Company" table="companyfk">
<id name="id" type="integer">
<column name="id"/>
<generator class="increment"/>
</id>
<property name="name" type="string">
<column name="name"/>
</property> <!-- 一对一外键关联
many-to-one:使用many-to-one
unique="true":设置companyfk表的外键唯一 addressid integer unique,
-->
<many-to-one name="address" column="addressid" unique="true"/>
</class>
</hibernate-mapping>
Address.hbm.xml 映射配置文件
<?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="cn.itcast.one2onefk.Address" table="addressfk">
<id name="id" type="integer">
<column name="id"/>
<generator class="increment"/>
</id>
<property name="city" type="string">
<column name="city"/>
</property> <property name="country" type="string">
<column name="country"/>
</property> <!-- 映射一对一
property-ref(互相引用):company属性管理的address这个属性
property-ref的值为Company这个类中的address属性(可以不加)
-->
<one-to-one name="company" property-ref="address"/> </class>
</hibernate-mapping>
App.java 测试代码
public class App {
private static SessionFactory sf=null;
static{
Configuration config=new Configuration();
config.configure("cn/itcast/one2onefk/hibernate.cfg.xml");
config.addClass(Company.class);
config.addClass(Address.class);
sf=config.buildSessionFactory();
}
/*
* 知识点1:测试保存
*/
@Test
public void saveCompanyAndAddress(){
Session session=sf.openSession();
Transaction tx=session.beginTransaction();
Company c=new Company();
c.setName("长城");
Address address=new Address();
address.setCity("上海");
address.setCountry("中国");
//建立关联
c.setAddress(address);
address.setCompany(c);
//保存
session.save(address);
session.save(c);
tx.commit();
session.close();
}
//知识点2:测试唯一性
@Test
public void testUnique(){
Session session=sf.openSession();
Transaction tx=session.beginTransaction();
Company c=new Company();
c.setName("天空网");
//获取一号地址
Address address=(Address)session.get(Address.class, 1);
//建立关联
c.setAddress(address);
address.setCompany(c);
//不能保存
session.save(c);
tx.commit();
session.close();
}
}
(2)主键关联
一对一的另一种解决方式就是主键关联,在这种关联关系中,要求两个对象的主键必须保持一致,一方既是主键又是外键,通过两个表的主键建立关联关系,无须外键参与。
foreign 策略,表明根据”对方”的主键来生成自己的主键,自己并不能独立生成主键.
<param> 子元素指定使用当前持久化类的哪个属性作为 “对方”
one-to-one 元素映射关联属性,其
one-to-one 属性还应增加
constrained=“true”属性;另一端(company)增加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="cn.itcast.one2onepk.Address" table="addresspk">
<id name="id" type="integer">
<column name="id"/>
<!--
foreign:表示addresspk表的主键的生成参照另一个表(companypk的)主键
这里addresspk表的主键值来源于companypk表的主键,不是该addresspk表自己生成
-->
<generator class="foreign">
<!--
property:该Address类对应表主键的生成,参照该类中的属性company
-->
<param name="property">company</param>
</generator> </id>
<property name="city" type="string">
<column name="city"/>
</property> <property name="country" type="string">
<column name="country"/>
</property> <!--one-to-one配置Address和Company的一对一关联
constrained="true":为addresspk增加外键约束
-->
<one-to-one name="company" constrained="true"/> </class>
</hibernate-mapping>
Company.hbm.xml
<?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="cn.itcast.one2onepk.Company" table="companypk">
<id name="id" type="integer">
<column name="id"/>
<generator class="increment"/>
</id>
<property name="name" type="string">
<column name="name"/>
</property> <!-- 配置Company和地址的一对一关联 -->
<one-to-one name="address"/> </class>
</hibernate-mapping>
Hibernate -- 一对一映射的更多相关文章
- Hibernate一对一映射关联
Hibernate提供了两种一对一映射关联关系的方式: 1)按照外键映射 2)按照主键映射 下面以员工账号表和员工档案表(员工账号和档案表之间是一对一的关系)为例,介绍这两种映射关系,并使用这两种 映 ...
- java框架篇---hibernate(一对一)映射关系
对象-关系映射(Object/Relation Mapping,简称ORM),是随着面向对象的软件开发方法发展而产生的,是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术,本质上就是将数据从 ...
- hibernate一对一映射
package loaderman.c_one2one; // 身份证 public class IdCard { // 身份证号(主键) private String cardNum;// 对象唯一 ...
- .Hibernate一对一映射与组件映射
1.按照外键映射(Hibernate提供了两种映射一对一关联关系的方式:按照外键映射和按照主键映射) 实现需要: 创建实体类Users1和Resume1 public class Users1 { p ...
- Hibernate 一对一映射(惟一外键)
- Hibernate 一对一映射(共享主键)
- hibernate笔记--基于主键的单(双)向的一对一映射关系
上一节介绍的基于外键的一对一映射关系中,在Person表中有一个外键列idCard_id,对应的idCard表的主键id,至于基于主键的一对一映射关系,就是指Person表中抛弃了idcard_id这 ...
- hibernate笔记--基于外键的单(双)向的一对一映射关系
假设我们有两张表,人员信息表Person,和身份信息表IdCard,我们知道每个人只有一个身份证号,所以这里的Person和IdCard表是一一对应的,也就是一对一的映射关系,基于外键的单向一对一映射 ...
- Hibernate一对一关系映射
Hibernate提供了两种一对一映射关联关系的方式: 1)按照外键映射 2)按照主键映射 下面以员工账号表和员工档案表(员工账号和档案表之间是一对一的关系)为例,介绍这两种映射关系,并使用这两种 映 ...
随机推荐
- Powershell 脚本调用方法
方法一: Get-Content "D:\PowershellScripts\Test\ErrorMailNotice.ps1" | Invoke-Expression 方法二: ...
- php 正则表达式二.基本语法
官方手册正则语法:http://php.net/manual/zh/reference.pcre.pattern.syntax.php 正则表达式在线测试工具:regexpal 正则表达式的匹配先后顺 ...
- Java 常用语法和数据结构
Collection 首先Java中的collection都是支持泛型和类型安全 由于Java单根继承, 所以不指定, 可以在collection里面放任何对象, collection会都当作obje ...
- Sending 'ccColor4B' (aka 'struct_ccColor4B') to parameter of incompatible type
今天遇到了如下的一个错误, Sending 'ccColor4B' (aka 'struct_ccColor4B') to parameter of incompatible type CiColor ...
- 2015-03-22——js常用其它方法
Function Function.prototype.method = function (name, func) { this.prototype[name] = func; //此时th ...
- Oracle 11g修改字符集AL32UTF8为ZHS16GBK
oracle11g更改字符集AL32UTF8为ZHS16GBK当初安装oracle的时候选择的默认安装,结果字符集不是以前经常用的16GBK,要改字符集,从网上找到了方法并试了一下,果然好用! 具体如 ...
- python列表套字典数据类型转换
1.题目 list3 = [ {'name':'Alex','hobby':'抽烟'}, {'name':'Alex', 'hobby':'喝酒'}, {'name':'Alex', 'hobby': ...
- less本地环境输出hello-world
在学任何东西之前, 我就是有个习惯, 先搞定这个东西最最简单的使用方法. 然后在 深入学习, 毫无疑问hello-world一直是那么简单. 准备环境 较新版的高级浏览器. WAMP环境. less. ...
- beego——高级查询
ORM以QuerySeter来组织查询,每个返回QuerySeter的方法都会获得一个新的QuerySeter对象. 基本使用方法: o := orm.NewOrm() // 获取 QuerySete ...
- Java技术学习路线
转载 作者:David 链接:https://www.zhihu.com/question/25255189/answer/86898400来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商 ...