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
近期热议
推荐标签 标签
-
flomo
6 引用 • 140 回帖
flomo 是新一代 「卡片笔记」 ,专注在碎片化时代,促进你的记录,帮你积累更多知识资产。
-
HHKB
5 引用 • 74 回帖 • 493 关注
HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。
-
TextBundle
1 引用 • 2 回帖 • 72 关注
TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。
-
智能合约
1 引用 • 11 回帖
智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。
-
Sublime
10 引用 • 5 回帖 • 3 关注
Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。
-
创业
82 引用 • 1395 回帖
你比 99% 的人都优秀么?
-
SVN
29 引用 • 98 回帖 • 687 关注
SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。
-
资讯
56 引用 • 85 回帖 • 1 关注
资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。
-
外包
26 引用 • 233 回帖 • 1 关注
有空闲时间是接外包好呢还是学习好呢?
-
sts
2 引用 • 2 回帖 • 222 关注
-
LaTeX
12 引用 • 54 回帖 • 18 关注
LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。
-
服务器
125 引用 • 585 回帖 • 1 关注
服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。
-
OpenCV
15 引用 • 36 回帖 • 1 关注
-
webpack
41 引用 • 130 回帖 • 253 关注
webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。
-
PostgreSQL
22 引用 • 22 回帖 • 1 关注
PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。
-
Webswing
1 引用 • 15 回帖 • 636 关注
Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用 。
-
DevOps
57 引用 • 25 回帖 • 5 关注
DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。
-
Electron
15 引用 • 136 回帖 • 7 关注
Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。
-
Kubernetes
116 引用 • 54 回帖
Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。
-
爬虫
106 引用 • 275 回帖 • 1 关注
网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。
-
开源
409 引用 • 3586 回帖
Open Source, Open Mind, Open Sight, Open Future!
-
GraphQL
4 引用 • 3 回帖
GraphQL 是一个用于 API 的查询语言,是一个使用基于类型系统来执行查询的服务端运行时(类型系统由你的数据定义)。GraphQL 并没有和任何特定数据库或者存储引擎绑定,而是依靠你现有的代码和数据支撑。
-
安装
132 引用 • 1184 回帖
你若安好,便是晴天。
-
Spark
74 引用 • 46 回帖 • 568 关注
Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。
-
Scala
13 引用 • 11 回帖 • 158 关注
Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。
-
RYMCU
4 引用 • 6 回帖 • 54 关注
RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。
-
Sym
524 引用 • 4601 回帖 • 699 关注
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于