Hibernate一对一外键双向关联(Annotation配置)
package edu.xaut.hibernate;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToOne;
@Entity
public class Student {
private int id;
private String name;
private String gender;
private int age;
private StuIdCard stuIdCard;
@Id
@GeneratedValue
public int getId() {
return id;
}
@Column(name = "name", length = 20)
public String getName() {
return name;
}
@Column(name = "gender", length = 6)
public String getGender() {
return gender;
}
public int getAge() {
return age;
}
@OneToOne
@JoinColumn(name = "StuIdCard")
public StuIdCard getStuIdCard() {
return stuIdCard;
}
public void setId(int id) {
this.id = id;
}
public void setName(String name) {
this.name = name;
}
public void setGender(String gender) {
this.gender = gender;
}
public void setAge(int age) {
this.age = age;
}
public void setStuIdCard(StuIdCard stuIdCard) {
this.stuIdCard = stuIdCard;
}
}
package edu.xaut.hibernate;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.OneToOne;
@Entity
public class StuIdCard {
private int id;
private String num;
private Student student;
@Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
@Column(length = 20)
public String getNum() {
return num;
}
public void setNum(String num) {
this.num = num;
}
@OneToOne(mappedBy="stuIdCard")
public Student getStudent() {
return student;
}
public void setStudent(Student student) {
this.student = student;
}
}
导出的SQL语句如下:
create table StuIdCard (
id integer not null auto_increment,
num varchar(20),
primary key (id)
)
create table Student (
id integer not null auto_increment,
age integer not null,
gender varchar(6),
name varchar(20),
StuIdCard integer,
primary key (id)
)
alter table Student
add index FKF3371A1BFDFA0D4 (StuIdCard),
add constraint FKF3371A1BFDFA0D4
foreign key (StuIdCard)
references StuIdCard (id)
测试代码如下:
package edu.xaut.hibernate;
import org.hibernate.Session;
import org.hibernate.cfg.*;
import org.hibernate.tool.hbm2ddl.SchemaExport;
import org.junit.Test;
import edu.xaut.wuqiang.hibernate.util.HibernateUtil;
public class HibernateORMappingTest {
@Test
public void testStudentSave() {
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
StuIdCard stuIdCard = new StuIdCard();
stuIdCard.setNum("1008120672");
session.save(stuIdCard);
Student stu = new Student();
stu.setName("Lily");
stu.setGender("Female");
stu.setAge(22);
stu.setStuIdCard(stuIdCard);
session.save(stu);
session.getTransaction().commit();
HibernateUtil.getSessionFactory().close();
}
@Test
public void testQueryStuInfo() {
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
StuIdCard stuIdCard = (StuIdCard) session.get(StuIdCard.class, 1);
System.out.println(stuIdCard.getNum());
System.out.println(stuIdCard.getStudent().getName() + "\t"
+ stuIdCard.getNum() + "\t"
+ stuIdCard.getStudent().getGender() + "\t"
+ stuIdCard.getStudent().getAge());
session.getTransaction().commit();
HibernateUtil.getSessionFactory().close();
}
@Test
public void testSchemaExport() {
new SchemaExport(new AnnotationConfiguration().configure()).create(
true, true);
}
}
运行结果如下:
select
stuidcard0_.id as id0_1_,
stuidcard0_.num as num0_1_,
student1_.id as id1_0_,
student1_.age as age1_0_,
student1_.gender as gender1_0_,
student1_.name as name1_0_,
student1_.StuIdCard as StuIdCard1_0_
from
StuIdCard stuidcard0_
left outer join
Student student1_
on stuidcard0_.id=student1_.StuIdCard
where
stuidcard0_.id=?
1008120672
Lily 1008120672 Female 22
http://blog.sina.com.cn/s/blog_4979ec3e010174nx.html
Hibernate一对一外键双向关联(Annotation配置)的更多相关文章
- hibernate一对一外键双向关联
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
- hibernate一对一外键单向关联
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
- hibernate一对一主键双向关联
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
- hibernate一对一主键单向关联
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
- Hibernate一对一外键映射
Hibernate 一对一外键映射 ------------------------------ ----- ...
- Hibernate,一对一外键单向 记录。Timestamp 的一个坑。
首先是2张表 表A: 表B: 其中表B中的FormBaseId对应表A中的SubjectID. 数据库中没有设置外键关系. 下面是2个对应的实体 package questionnaire.model ...
- Hibernate,关系映射的多对一单向关联、多对一双向关联、一对一主键关联、一对一外键关联、多对多关系关联
2018-11-10 22:27:02开始写 下图内容ORM.Hibernate介绍.hibername.cfg.xml结构: 下图内容hibernate映射文件结构介绍 下图内容hibernate ...
- hibernate之关于一对一单向,双向关联映射
[hibernate]之关于一对一单向,双向关联映射 首先我们来看,Hibernate官方对于一对一单向关联的解释: 基于外键关联的单向一对一关联和单向多对一关联差点儿是一样的. 唯一的不同就是单向一 ...
- ORM框架Hibernate (四) 一对一单向、双向关联映射
简介 在上一篇博客说了一下多对一映射,这里再说一下一对一关联映射,这种例子在生活中很常见,比如一个人的信息和他的身份证是一对一.又如一夫一妻制等等. 记得在Java编程思想上第一句话是“一切皆对象”, ...
随机推荐
- Kettle使用介绍
本文主要阅读目录如下: 1.Kettle概念 2.下载和部署 3.Kettle环境配置 4.Kettle使用及组件介绍 ETL(Extract-Transform-Load的缩写,即数据抽取.转换.装 ...
- 支持Cookie并开放了一些特殊设置项的HttpWebClient
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.N ...
- Adaptive Decontamination of the Training Set: A Unified Formulation for Discriminative Visual Tracking
Martin Danelljan 判决类追踪模型是由训练样本学习得到,但是为了适应目标和背景的变化sample set在每一帧中都会更新. 令(xjk, yjk)表示第k帧k={1,2,...,t}中 ...
- MyBatis入门学习教程-优化MyBatis配置文件中的配置
一.连接数据库的配置单独放在一个properties文件中 之前,我们是直接将数据库的连接配置信息写在了MyBatis的conf.xml文件中,如下: 1 <?xml version=" ...
- EL总结
El: 1.el表达式语言(是什么) 2.el是书写到jsp页面 3.el语法格式${ } 4.el算数运算(+,-,*,/,%), 逻辑运算(&&,||,!), 关系运算(>, ...
- 各公司年资金归集汇总sql
select bd_accid.accidcode, bd_accid.accidname, -- fts_voucher_b.interestdate, -- fts_voucher_b.summa ...
- Android学习笔记(十)
Android控件——ListView ListView允许用户通过手指上下滑动的方式将屏幕外的数据滚动到屏幕内,同时 屏幕上原有的数据则会滚动出屏幕. 1.ListView的简单用法 新建一个Lis ...
- Android生命周期
Android的生命周期如下图所示: A和B两个Activity,从A启动B活动.执行的方法: A活动 onCreate() onStart() onResume() ...
- 给flash添加A链接
项目中,曾有一个需求,给flash广告添加链接,跳转到另一个网站.于是直接在html的flash object前面加上<a href="url">,发现链接不起作用. ...
- 关于语句#ifdef OS_GLOBALS #define OS_EXT #else #define OS_EXT extern #endif 的说明
声明全局变量使用的技术——摘自uC/OS-II中文版 以下是如何定义全局 变量.众所周知,全局变量应该是得到内存分配且可以被其他模块通过C 语言中extern 关键字调用的变量.因此,必须在 .C 和 ...