Hibernate一对多、多对一关联
一对多、多对一关联:在多方加外键
示例:Group(一方)和User(多方),一个Group可以有多个User,每个User只能属于一个Group
多对一单向关联
在User(多方)中建Group(一方)对象,并添加@ManyToOne注解
1.建Group实体类和User实体类,添加Annotation注解,如下
@Entity
@Table(name="_group") //group在MySQL中是关键字,不能直接做表名
public class Group {
private int id;
private String name;
@Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
@Entity
@Table(name="_user") //为了和表_group保持一致,也用一个别名
public class User {
private int id;
private String name; private Group group; @Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
} @ManyToOne //多对一关联
// @JoinColumn(name="groupId") //任意指定生成的外键名
public Group getGroup() {
return group;
}
public void setGroup(Group group) {
this.group = group;
}
}
2.在hibernate.cfg.xml中添加mapping语句
<mapping class="com.hibernate.model.Group"/>
<mapping class="com.hibernate.model.User"/>
3.建Junit测试类
public class ORMappingTest {
	@Test
	public void test() {
		new SchemaExport(new Configuration().configure()).create(true, true);
	}
}
程序至此结束,运行程序,在数据库中生成表_group和表_user,并在控制台输出建表语句。
_user表中会自动生成属性名为group_id的外键,可用@JoinColumn注解修改其属性名
一对多单向关联
在Group(一方)中建User(多方)对象,此对象采用Set集合形式
并添加@ManyToOne和@JoinColumn注解(必须添加)
1.建Group实体类和User实体类,添加Annotation注解,如下
@Entity
@Table(name="_group") //group在MySQL中是关键字,不能直接做表名
public class Group {
private int id;
private String name; private Set<User> users = new HashSet<User>(); //新建Set集合形式的多方对象users @Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
} @OneToMany //一对多关联
@JoinColumn(name="groupId") //若不添加该属性,则会在数据库中生成三张表。
public Set<User> getUsers() {
return users;
}
public void setUsers(Set<User> users) {
this.users = users;
}
}
@Entity
@Table(name="_user") //为了和表_group保持一致,也用一个别名
public class User {
private int id;
private String name; @Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
2.在hibernate.cfg.xml中添加mapping语句----同上
3.建Junit测试类----同上
程序至此结束,运行程序,会在数据库中生成表_group和表_user,并在控制台输出建表语句
_user表中会生成指定属性名的外键
一对多、多对一双向关联
在User中建Group对象,并添加@ManyToOne注解;在Group中建User对象,并添加@OneToMany注解
1.建Group实体类和User实体类,添加Annotation注解
User类同“多对一单向关联”部分的User类
Group类,如下:
@Entity
@Table(name="_group") //group在MySQL中是关键字,不能直接做表名
public class Group {
private int id;
private String name; private Set<User> users = new HashSet<User>(); @Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
} @OneToMany(mappedBy="group") //这里的"group"是指User类中的private Group group;
public Set<User> getUsers() {
return users;
}
public void setUsers(Set<User> users) {
this.users = users;
}
}
2.在hibernate.cfg.xml中添加mapping语句----同上
3.建Junit测试类----同上
程序至此结束,
运行程序,会在数据库中生成表_group和表_user,并在控制台输出建表语句
_user表中会自动生成属性名为group_id的外键,可用@JoinColumn注解修改其属性名
@mappedBy含义
1.单向关系不需要设置该属性,双向关系必须设置,避免双方都建立外键字段
2.只有OneToOne,OneToMany,ManyToMany上才有mappedBy属性,ManyToOne不存在该属性
3.mappedBy跟JoinColumn/JoinTable总是处于互斥的一方
以Group(一方)和User(多方)为例,
外键在User(多方),@JoinColumn/@JoinTable则只能设置在User(多方)。
则@mappedBy设置在Group(一方)。表明此关联关系是由User(多方)维护的。
Hibernate一对多、多对一关联的更多相关文章
- Hibernate ManyToOne Mappings 多对一关联映射
		
Hibernate ManyToOne Mappings 多对一关联映射 Hibernate框架的使用步骤: 1.创建Hibernate的配置文件(hibernate.cfg.xml)2.创建持久化类 ...
 - Hibernate   一对多/多对多
		
一对多关联(多对一): 一对多关联映射: 在多的一端添加一个外键指向一的一端,它维护的关系是一指向多 多对一关联映射: 咋多的一端加入一个外键指向一的一端,它维护的关系是多指向一 在配置文件中添加: ...
 - Hibernate 配置双向多对多关联
		
本文解决问题:Hibernate 中配置项目(Project) 员工(Employee) 双向多对多关联 方案一:直接配置双向多对多 方案二:配置第三个关联类(xml) 将多对多查分开来(形成 ...
 - Hibernate一对多(多对一)关联关系
		
上一篇博文总结了 Hibernate 的一对一的关联关系, 包括基于主键的单向一对一, 基于外键的单向一对一, 基于外键的双向一对一. 下面咱们说一下 Hibernate 的一对多关联关系. 其实一对 ...
 - hibernate一对多多对一双向
		
注意事项:一对多,多对一双向关联,在一的一方的多的getSet集合上的oneToMany上加上mappedBy.告诉hibernate由多的方一来维护关系.这也符合逻辑 ,本来外键就是在加在多的一方. ...
 - hibernate  一对多 多对一 关系表 增删改查大礼包ps二级查也有
		
今天来到混元气功 这货大概的意思就是你中有我 我中有你 ps 这里就要说到维护关系 ps写这个用了我一下午.......也是刚刚好复习到这里 顺便就写写 注意:一般都在多方维护关系,至于是用单向还是用 ...
 - 6.Hibernate单向的多对一 关联映射
		
1.创建如下项目结构 2.在项目的src下创建hibernate.cfg.xml主配置文件 <?xml version="1.0" encoding="UTF-8& ...
 - Hibernate框架单向多对一关联映射关系
		
建立多对一的单向关联关系 Emp.java private Integer empNo //员工编号 private String empName / ...
 - Hibernate框架双向多对多关联映射关系
		
建立双向多对多关联关系 Project.java (项目表) private Integer proid; private Strin ...
 - Hibernate框架单向多对多关联映射关系
		
建立单向多对多关联关系 Project.java (项目表) private Integer proid; private Strin ...
 
随机推荐
- c#的bug?
			
在群里面有人提出了这么一个诡异的问题,请问15.5%3.1=? 然后,我就去看了看,因为他们说结果是3.1!!!
 - cmake工程使用distcc
			
distcc可以加速编译,但是遇到cmake可能就需要处理下. 问题 distcc在 /usr/lib/distcc 中放了各编译器的soft link(如cc/gcc等等),如果 /usr/lib/ ...
 - HDU 5355 Cake(2015多校第六场,搜索 + 剪枝)
			
Cake Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Total Sub ...
 - Cmder 配置使用
			
官网下载 配置: 1.把 Cmder 加到环境变量 将Cmder.exe存放的目录添加到系统环境变量path 添加成功后,Win+r 输入cmder,可以正确打开cmder 窗口即可. 2.添加 cm ...
 - 大数据实战centos 6.7安装mysql5.7
			
https://www.cnblogs.com/jr1260/p/6590232.html
 - references non-existing project XXX, launch configuration问题的解决办法
			
Go to Project->properties In properties window's left pane select "Run/Debug Settings". ...
 - Java NIO(1):迟迟登场的NIO
			
Java NIO的出现 Java语言发展至今,优点大家有目共睹:面向对象的语言.简洁有效.高移植性等等.但是同样也存在很多缺点,C语言程序员口中Java太慢了,.net程序员口中Java太开放了,ph ...
 - android 细节之 AndroidRuntimeException:This message is already in use
			
今天在做项目处理消息队列的时候.遇到了这样一个问题.一个异常.AndroidRuntimeException:This message is already in use. 我当时的详细业务需求情境为 ...
 - 椭圆参数方程中的θ(离心角Theta)
			
椭圆参数方程中的离心角θ是交以其x轴对应外接圆上点的角度(或是交以其y轴对应内接圆上点的角度) 椭圆的参数程为:x=acosθy=bsinθ.M(x,y)椭圆上一点.过M作直线⊥X轴,交以O为圆心,以 ...
 - Win API:之GetCurrentThread、GetCurrentThreadId、GetCurrentProcess、GetCurrentProcessId
			
Win API:之GetCurrentThread.GetCurrentThreadId.GetCurrentProcess.GetCurrentProcessId {返回当前线程的虚拟句柄} Get ...