事实上,单向1-1与N-1的实质是相同的,1-1是N-1的特例,单向1-1与N-1的映射配置也非常相似。只需要将原来的many-to-one元素增加unique="true"属性,用于表示N的一端也必须是唯一的,在N的一端增加了唯一的约束,即成为单向1-1。基于外键的单向1-1的配置将与无连接表N-1关联的many-to-one增加unique="true"属性即可。

一、模型介绍

一个人(account)对应一个地址(address)。

二、实体

account类

package entity;

import java.io.Serializable;
public class account implements Serializable{
public account(){ }
// 建议hibernate中不用使用id,name这种关键字 可能会报错
private int account_id;
private String account_name;
private String password;
//需要添加被控端的引用 此处添加的是对应关系 即一个人对应一个地址的地址对象
private address address; public int getAccount_id() {
return account_id;
}
public void setAccount_id(int account_id) {
this.account_id = account_id;
}
public String getAccount_name() {
return account_name;
}
public void setAccount_name(String account_name) {
this.account_name = account_name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public address getAddress() {
return address;
}
public void setAddress(address address) {
this.address = address;
}
}

address实体类

package entity;

import java.io.Serializable;

public class address implements Serializable{
public address(){
}
private int address_id;
private String address_name; public int getAddress_id() {
return address_id;
}
public void setAddress_id(int address_id) {
this.address_id = address_id;
}
public String getAddress_name() {
return address_name;
}
public void setAddress_name(String address_name) {
this.address_name = address_name;
}
}

映射关系配置
account.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 = "entity.account" table ="account">
<id column = "account_id" name = "account_id">
<generator class="native"/> <!--主键生成方式 所以在创建表的时候要主键自增
--> </id>
<property name="account_name" type = "java.lang.String" column = "account_name"/>
<property name="password" type="java.lang.String" column = "password"/>
<!-- 通过many-to-one 标签添加唯一属性约束,建立一对一关联关系
此处映射的意思是 account的adress属性对应着外表的address_id列 且填加了唯一约束 说明address_id是唯一的 -->
<many-to-one name="address" column="address_id" 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 = "entity.address" table = "address">
<id name="address_id" column="address_id">
<generator class="native"/>
</id>
<!-- generated= never 标明此属性值不是从数据库中生成。generated默认值是never。
generated= insert 标明此属性值在insert的时候生成,但是不会在随后的update时重新生成。
generated= always 标明此属性值在insert和update时都会被生成
-->
<property name="address_name" type = "java.lang.String" column = "address_name" generated="never" lazy="false"/>
</class>
</hibernate-mapping>

这里讲通用逻辑封装成了一个方法了

/**
* @author Administrator
*
*/
package HibernateUtil; import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration; public class HibernateUtil {
private static SessionFactory factory;
static{
Configuration cnn = new Configuration().configure();
factory = cnn.buildSessionFactory();
}
public static SessionFactory getSessionFactory(){
return factory;
}
public static Session getOneSession(){
return factory.openSession();
}
public static void ClossSession(Session session){
if(session != null){
session.close();
}
}
}

建表就不说了但是注意不要忘记创建自增和索引名字必须是Hibernate.sequence .
hibernate.hbm.xml同Hibernate学习一中的配置只是添加了映射文件 <mapping resource="account.hbm.xml"/><mapping resource="address.hbm.xml"/>

测试

package text;

import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test; import entity.account;
import entity.address; import HibernateUtil.HibernateUtil; public class textManytoOne { @Test
public void add(){
Transaction tx = null;
Session session = HibernateUtil.getOneSession();
tx=session.beginTransaction(); address address = new address();
address.setAddress_name("天津");
session.save(address); account account = new account();
account.setAccount_name("大伟哥666");
account.setPassword("123456");
account.setAddress(address); // 重复添加 account account1 = new account();
account1.setAccount_name("小老虎666");
account1.setPassword("123456");
account1.setAddress(address); try{
session.save(account);
session.save(account1);
tx.commit();
}catch(HibernateException e){
e.printStackTrace();
tx.rollback();
}finally{
HibernateUtil.ClossSession(session);
}
}
}

总结注意
1.在多表实体类中记得添加被控端的对象的引用 且属性名字最好不用和关键字冲突

2.要在多表的映射文件中写上<many-to-one name="被控端引用对象" column="外键 也就是另一张表的主键" unique="是否对外键加唯一">

3.创建表的时候主键索引名字是Hibernate.sequence 不知道为什么  但是我的名字不是这个就报错

4.Hibernate的配置文件中记得添加实体类的映射文件 <mapping resource="xxx.hbm.xml">

Hibernate学习(二)关系映射----基于外键的单向一对一的更多相关文章

  1. Hibernate学习(二补充)关系映射----基于外键的双向一对一

    刚刚写的是基于外键的单向一对一.  那么双向一对一就是在单向一对一的基础上稍微改动就可以了. account.java和account.hbm.xml都不用变动  只要我们小小的变动address.j ...

  2. Hibernate关系映射(一) 基于外键的单向一对一

    模拟用户和地址的映射关系,一个用户只有一个地址,用户知道地址,但是地址不知道用户.用户对地址的单向一对一映射. 一.建立实体类 Account.cs类 package com.lxit.entity; ...

  3. Hibernate关系映射(二) 基于外键的双向一对一

    基于外键的双向一对一关联映射 需要在一端添加<one-to-one>标签,用property-ref来指定反向属性引用. 还是通过刚才用户和地址来演示双向一对一关联. 代码演示 一.实体类 ...

  4. Hibernate 基于外键的双向一对一关联映射

    之前简单介绍了基于外键的单项一对一的关联映射关系,本文简单介绍基于外键的双向一对一的关联映射. 1.设计表结构 表结构对于双向一对一来说没有多少改变,只是双向都可以获取到对方. 2.创建Person对 ...

  5. java之hibernate之基于外键的双向一对一关联映射

    这篇讲解 基于外键的双向一对一关联映射 1.考察如下信息,人和身份证之间是一个一对一的关系.表的设计 2.类结构 Person.java public class Person implements ...

  6. java之hibernate之基于主键的单向一对一关联映射

    这篇讲 基于主键的单向一对一关联映射 1.依然考察人和身份证的一对一关系,如果采用主键关联,那么其表结构应该为: 2.类结构 Person.java public class Person imple ...

  7. Hibernate(八):基于外键映射的1-1关联关系

    背景: 一个部门只有一个一把手,这在程序开发中就会设计数据映射应该设置为一对一关联. 在hibernate代码开发中,实现这个业务有两种方案: 1)基于外键映射的1-1关联: 2)基于主键映射的1-1 ...

  8. hibernate 基于主键的单向一对一关联映射

    1.设计表结构 表结构对于基于外键的关联关系来说就少了外键的关联列,并且两张表共用同一个ID,表示一对一. 2.创建Person对象 3.创建IdCard对象 4.写hbm.xml文件 5.生成数据库 ...

  9. Hibernate学习之关系映射(转)

    一.一对多 "一对多"是最普遍的映射关系,简单来讲就如消费者与订单的关系.一对多:从消费者角的度来说一个消费者可以有多个订单,即为一对多.多对一:从订单的角度来说多个订单可以对应一 ...

随机推荐

  1. Unable to open debugger port (127.0.0.1:51554): java.net.SocketException "socket closed"

    刚开始使用IDEA 总是有各种各样奇葩的问题 启动报错: Unable to open debugger port (127.0.0.1:51554): java.net.SocketExceptio ...

  2. 最近折腾老机器:还是 Xp 最好!

    闲来无事,折腾机器. -------------------------------------------------------------- 硬件: CPU:amd x2450 Memory:6 ...

  3. 2016-2017 ACM-ICPC, NEERC, Southern Subregional Contest J. Bottles

    J. Bottles time limit per test 2 seconds memory limit per test 512 megabytes input standard input ou ...

  4. 解析 C# 7中的元组类型(ValueTuple)

    System.Tuple 类型是在.NET 4.0中引入的,但是有两个明显的缺点: (1) Tuple 类型是引用类型. (2) 没有构造函数支持. 为了解决这些问题,C# 7 引入了新的语言功能以及 ...

  5. SSH三大框架整合步骤

    Struts2:需要整合的第一个框架: 1.创建一个动态web项目 2.导入struts2必须的jar 放到 lib目录下 ,再 build path 添加web工程中 3.配置struts2的核心配 ...

  6. Android 开发笔记___FrameLayout

    xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:la ...

  7. eclipse安装checkstyle无法加载到preferences的问题

    描述一下问题,eclipse安装checkstyle,不管是在线安装还是下载安装,在preferences都没有checkstyle选项,如下: 然我们要的效果是这样的:   解决方案如下: 1 启动 ...

  8. 虚拟软件vmware安装

    什么是虚拟软件: 虚拟原件是一个可以使你在一台机器上同时运行二个或更多Windows.LINUX等系统.它可以模拟一个标准PC环境.这个环境和真实的计算机一样,都有芯片组.CPU.内存.显卡.声卡.网 ...

  9. 如何兼容所有Android版本选择照片或拍照然后裁剪图片--基于FileProvider和动态权限的实现

    我们知道, Android操作系统一直在进化. 虽然说系统是越来越安全, 可靠, 但是对于开发者而言, 开发难度是越来越大的, 需要注意的兼容性问题, 也越来越多. 就比如在Android平台上拍照或 ...

  10. javaMybatis映射属性,高级映射

    映射文件的sql属性: id:标识符(一般都是dao层方法名) resultType:sql返回类型 resultMap:放回的映射类型 parameterType:参数类型 useGenerated ...