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编程思想上第一句话是“一切皆对象”, ...
随机推荐
- DevWebForm控件,触发用客户端事件
ClientInstanceName+".Raise"+"事件名", 例如: ClientInstanceName.RaiseValueChanged();
- java sdk与jdk区别
SDK是Software Development Kit的缩写,中文意思是"软件开发工具包".这是一个覆盖面相当广泛的名词,可以这么说:辅助开发某一类软件的相关文档.范例和工具的集 ...
- HDU 1394 Minimum Inversion Number(最小逆序数 线段树)
Minimum Inversion Number [题目链接]Minimum Inversion Number [题目类型]最小逆序数 线段树 &题意: 求一个数列经过n次变换得到的数列其中的 ...
- 【转】EXCEL不显示科学计数法
源地址:http://jingyan.baidu.com/article/e4d08ffdcc304e0fd3f60d69.html 2法无效,不知道为何
- [SQL]复制数据库某一个表到另一个数据库中
SQL:复制数据库某一个表到另一个数据库中 SELECT * INTO 表1 FROM 表2 --复制表2如果只复制结构而不复制内容或只复制某一列只要加WHERE条件就好了 例子:SELECT * I ...
- 第一周:设计一个简易ATM取款机简易程序(2)
1.了解用户对ATM取款机功能需求如下: 2.新建一个login函数使用for循环方法和if选择方法编写登陆界面用来及设置ATM内用户的金额和取款机内的金额: 3.使用新建函数方法及if选择方法编写登 ...
- [DFNews] Touch ID不是神话,指模依旧能搞定。
扫描制作翻模,使用含石墨硅胶压膜,前者复制指纹纹路,后者欺骗活体检测.
- springmvc 接受特殊类型字段的处理方法
springmvc接受前台传入的数据时如果该字段类型无法被封装(如Date),则会出现400 Bad Request错误,解决方法如下. 1.在需要处理的字段前加上注解: @DateTimeForma ...
- tomcat6配置jndi连接数据库的方式
eworkflow工作流+eform表单+ebiao报表集成在一起,用tomcat6发布,并用jndi连接数据库,数据库是sqlserver2005,配置如下: 1.在tomcat6\conf\con ...
- HEVC学习之二CTU, CU, CTB, CB, PB, TB
在H264标准中,编码层的核心是宏块,一个宏块大小为16X16,包含一个16X16的亮度块,以及对于常用的4:2:0采样格式来说还包含两个8X8的色度块.相对应的在HEVC中类似的结构为编码树单元(C ...