- 浏览: 2990018 次
- 性别:
- 来自: 河南
文章分类
- 全部博客 (340)
- Java综合 (26)
- 程序人生 (53)
- RIA-ExtJS专栏 (18)
- RIA-mxGraph专栏 (4)
- RIA-Flex4专栏 (43)
- 框架-Spring专栏 (16)
- 框架-持久化专栏 (22)
- 框架-Struts2专栏 (11)
- 框架-Struts专栏 (12)
- SQL/NOSQL (12)
- 报表/图表 (2)
- 工作流 (5)
- XML专栏 (4)
- 日常报错解决方案 (5)
- Web前端-综合 (12)
- Web/JSP (14)
- Web前端-ajax专栏 (14)
- Web前端-JQuery专栏 (9)
- IDE技巧 (6)
- FILE/IO (14)
- 远程服务调用 (2)
- SSO单点登录 (2)
- 资源分享 (22)
- 云计算 (1)
- 项目管理 (3)
- php专栏 (1)
- Python专栏 (2)
- Linux (1)
- 缓存系统 (1)
- 队列服务器 (1)
- 网络编程 (0)
- Node.js (1)
最新评论
-
hui1989106a:
我的也不能解压,360和好压都试了,都不行
《Spring in Action》完整中文版分享下载 -
temotemo:
这些example有些过时了,官方建议使用HBase-1.0 ...
Java操作Hbase进行建表、删表以及对数据进行增删改查,条件查询 -
zy8102:
非常感谢~
HeadFirst系列之七:《深入浅出SQL》原版高清PDF电子书分享下载 -
zy8102:
重命名了一下搞定了
HeadFirst系列之七:《深入浅出SQL》原版高清PDF电子书分享下载 -
zy8102:
为什么下载以后老解压不了呢?
HeadFirst系列之七:《深入浅出SQL》原版高清PDF电子书分享下载
hibernate一对一唯一外键关联映射(单向关联Citizen---->IDCard)
一对唯一外键关联映射是多对一关联映射的特例
基于外键关联的单向一对一关联和单向多对一关联几乎是一样的。唯一的不同就是单向一对一关联中的外键字段具有唯一性约束。只需要将原来的many-to-one元素增加unique="true"属性,用于表示N的一端也必须是唯一的,在N的一端增加了唯一的约束,即成为单向1-1。
具体做法
1. 单向一对一关联:对象模型和关系模型不匹配。
对象模型上:主控方持有被控方实体类的引用。
关系模型上:主控方对应表中添加一个外键引用自被控方的主键,这个外键必须添加唯一约束。
2. 在主控方的映射文件中:
<many-to-one name="属性名" column="外键名" unique="true" [cascade="all"]/>
Citizen.java
package com.javacrazyer.domain;
public class Citizen {
private Long id;
private String name;
private Boolean gender;
//一对一关联中:主控方持有被控方的引用
private IDCard idCard;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Boolean getGender() {
return gender;
}
public void setGender(Boolean gender) {
this.gender = gender;
}
public IDCard getIdCard() {
return idCard;
}
public void setIdCard(IDCard idCard) {
this.idCard = idCard;
}
public String toString(){
return "id=" + this.id + ",name=" + this.name + ",gender=" + this.gender;
}
}
IDCard.java
package com.javacrazyer.domain;
public class IDCard {
private Long id;
private String no;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getNo() {
return no;
}
public void setNo(String no) {
this.no = no;
}
public String toString(){
return "id=" + id + ",no=" + this.no;
}
}
Citizen.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="com.javacrazyer.domain.Citizen">
<id name="id" column="id">
<generator class="native"/>
</id>
<property name="name"/>
<property name="gender"/>
<!-- 映射基于外键一对一关联 -->
<many-to-one name="idCard" column="card_id" unique="true" cascade="all"/>
</class>
</hibernate-mapping>
IDCard.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="com.javacrazyer.domain.IDCard" >
<id name="id" column="id">
<generator class="native"/>
</id>
<property name="no"/>
</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>
<!-- 数据库连接参数配置 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///test</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">root</property>
<!-- 数据库言的配置 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.show_sql">true</property>
<property name="hibernate.format_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
<!-- 声明实体关系映射文件 -->
<mapping resource="com/javacrazyer/domain/IDCard.hbm.xml" />
<mapping resource="com/javacrazyer/domain/Citizen.hbm.xml" />
</session-factory>
</hibernate-configuration>
启动下Hibernate,自动生成数据库表,数据库表的DDL语句如下
idcard表
create table `test`.`idcard`(
`id` BIGINT not null auto_increment,
`no` VARCHAR(255),
primary key (`id`)
);
create unique index `PRIMARY` on `test`.`idcard`(`id`);
citizen表
create table `test`.`citizen`(
`id` BIGINT not null auto_increment,
`name` VARCHAR(255),
`gender` BIT,
`card_id` BIGINT unique,
primary key (`id`)
);
alter table `test`.`citizen`
add index `FK92029348E9FA33E0`(`card_id`),
add constraint `FK92029348E9FA33E0`
foreign key (`card_id`)
references `test`.`idcard`(`id`);
create unique index `PRIMARY` on `test`.`citizen`(`id`);
create unique index `card_id` on `test`.`citizen`(`card_id`);
create index `FK92029348E9FA33E0` on `test`.`citizen`(`card_id`);
Hibernate辅助类
package com.javacrazyer.common;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
/**
* Hibernate工具类
*
*/
public class HibernateUtil {
private static final SessionFactory factory;
private HibernateUtil(){}
static{
//加载Hibernate全局配置文件,根据配置信息创建SessionFactory工厂实例
factory = new Configuration().configure().buildSessionFactory();
}
public static SessionFactory getSessionFactory(){
return factory;
}
}
测试类
package com.javacrazyer.test;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
import com.javacrazyer.common.HibernateUtil;
import com.javacrazyer.domain.Citizen;
import com.javacrazyer.domain.IDCard;
public class MappingTest {
private static SessionFactory sessionFactory;
@BeforeClass
public static void init(){
sessionFactory = HibernateUtil.getSessionFactory();
}
@AfterClass
public static void destroy(){
sessionFactory = null;
}
@Test
public void testSave(){
Session session = sessionFactory.openSession();
session.beginTransaction();
IDCard ic = new IDCard();
ic.setNo("xx0001");
Citizen citizen = new Citizen();
citizen.setName("赵C");
//设置一对一的关联
citizen.setIdCard(ic);
session.save(citizen);
session.getTransaction().commit();
session.close();
}
@Test
public void testGet(){
Session session = sessionFactory.openSession();
session.beginTransaction();
Citizen c = (Citizen)session.get(Citizen.class, Long.valueOf(1));
System.out.println(c.getName());
IDCard idcard = c.getIdCard();
System.out.println(idcard.getId());
session.getTransaction().commit();
session.close();
System.out.println(idcard.getNo());
}
}
评论
2 楼
JavaCrazyer
2010-11-14
Javakeith 写道
学框架 就看LZ的温习OK了! 谢谢LZ的分享!
1 楼
Javakeith
2010-11-14
学框架 就看LZ的温习OK了! 谢谢LZ的分享!
发表评论
-
ibatis常用16条SQL语句
2011-07-29 11:08 26020(1) 输入参数为单个值 ... -
iBATIS与Hibernate的异同
2010-12-30 14:47 3664Hibernate Hibernate是一个开放源代 ... -
iBATIS与Spring整合
2010-12-30 14:34 4851接着iBATIS的入门实例来说,ibatis与Spring的 ... -
Hibernate温习(17)--OpenSessionInView模式
2010-11-11 17:04 4527在WEB应用程序中,视图(JSP或Servlet)可能会通过导 ... -
Hibernate温习(16)--性能优化之缓存管理
2010-11-11 16:02 17581.缓存概述 缓存(cache) ... -
Hibernate温习(15)--性能优化之抓取策略
2010-11-11 14:51 3489抓取策略(fetching strategy) 是指:当应 ... -
Hibernate温习(14)--性能优化之延迟加载机制
2010-11-11 11:33 1723延迟加载 延迟加载 ... -
Hibernate温习(13)--Hibernate程序性能优化的考虑要点
2010-11-11 10:55 1310本文依照HIBERNATE帮助文档,一些网络书籍及项目经 ... -
Hibernate温习(12)--基于注解方式的各种映射全面总结
2010-11-11 10:43 35691. 使用Hibernate Annotation来做对 ... -
Hibernate温习(11)--多事务并发访问控制
2010-11-11 10:25 7407在并发环境,一个数据库系统会同时为各种各样的客户程序 ... -
Hibernate温习(10)--应用程序中的事务管理
2010-11-11 09:26 1899事务的定义 事务就是指作为单个逻辑工作单元执行的一组数据操作 ... -
Hibernate温习(9)--有关Hibernate升级后注解方式的对象关系映射
2010-11-10 17:06 3301我要说的升级指的是我实际中遇到的,由于我之前的项目中Hiber ... -
Hibernate进行测试时时常会有的错误
2010-11-10 14:31 1450在hibernate程序中,如果使用JUNIT进行测试的话,第 ... -
Hibernate温习(8)--使用JPA
2010-11-10 11:00 2333这次讲的JPA前一篇文章都有所介绍,这里呢就是结合hibern ... -
Hibernate温习(7)--JPA回顾
2010-11-10 10:39 1944什么是JPA JPA(Java Pers ... -
Hibernate温习(5)--集合属性映射
2010-11-04 22:37 2419Hibernate的集合属性映射 ... -
Hibernate温习(3)--有关session的总结
2010-11-04 17:22 4209说到Hibernate那么最核心的就是它的有关数据库的增删改查 ... -
Hibernate温习(1)--最基础的示例
2010-11-04 14:22 3420有关Spring的知识大部分都已经温习完毕,今天开始转向Hib ... -
ibatis入门实例讲解
2010-10-25 10:39 12938之前大家上网的ibatis官方网站:http://www.i ... -
HIbernate温习(2)--连接池配置总结基于第三方c3p0和proxool
2010-07-26 14:42 3407一直都在用连接池技术,也是个好习惯,但用连接 ...
相关推荐
hibernate one-to-one 一对一唯一外键关联映射_单向 and 双向
NULL 博文链接:https://zhouhaitao.iteye.com/blog/1171227
Hibernate 一对一外键单向关联 Hibernate 一对一主键单向关联 Hibernate 一对一连接表单向关联 Hibernate 一对多外键单向关联 Hibernate 一对多连接表单向关联 Hibernate 多对一外键单向关联 Hibernate 多对一连接...
博文链接:https://shaqiang32.iteye.com/blog/201311
hibernate外键实现一对一单向关联关系源码
│ ├─ 一对一外键单向关联 │ ├─ 一对一主键单向关联 │ ├─ 一对一连接表单向关联 │ ├─ 一对多外键单向关联 │ ├─ 一对多连接表单向关联 │ ├─ 多对一外键单向关联 │ ├─ 多对一连接表单向关联 │ └...
Hibernate 一对多 外键 单向关联,有例子。
博文链接:https://shaqiang32.iteye.com/blog/201312
Hibernate一对一外键映射实例,里面包含源程序,测试程序,映射文档
个人的很详细的Hibernate一对一映射配置详解,对初学者有帮助!
NULL 博文链接:https://ganshisheng.iteye.com/blog/434420
hibernate一对一外键关系,很适合入门者学习.
NULL 博文链接:https://12345678.iteye.com/blog/723871
http://blog.csdn.net/e421083458/article/details/8794127 该源码为Hibernate教程配套源码
NULL 博文链接:https://paladin1988.iteye.com/blog/1627597
博文链接:https://llying.iteye.com/blog/220804
NULL 博文链接:https://cdxs2.iteye.com/blog/1932507
14_多对一关联关系的映射与原理分析 15_多对一关联关系的检索与原理分析 16_保存多对一关联关系的更进一步分析 17_一对多关联关系的映射与原理分析 18_一对一主键关联关系的映射与原理分析 19_一对一主键关联...
NULL 博文链接:https://huihai.iteye.com/blog/1243558