在Annotation 中有这么一个@mappedBy 属性注解,相信有些同学还是对这个属性有些迷惑,上网找了些理解@mappedBy比较深刻的资料,下面贴出来供大家参考。
http://xiaoruanjian.iteye.com/blog/1094253
http://blog.csdn.net/gabriel80/article/details/4260923
看完资料后,我自己也总结了下,。
1.@mappedBy 属性简单理解为
设定为主表(这只是我个人理解,上面文章中也有提到过)
所以另一端则需要设置外键@JoinColumn(name="fk_id")
2.@OneToMany 注解下返回Set集合(列如:上帝可以有多个信徒)。
3.@ManyToOne 注解下
设置外键 根据
外键获取到主表对象只能获取到一个对象(列如:信徒只能有一个上帝)。
主表(God)
private Set believer= new HashSet(0);
public void setBeliever(Set<Believer> believer){
this.believer= believer;
}
@OneToMany(cascade = { CascadeType.MERGE }, fetch = FetchType.LAZY, mappedBy = "God")
public Set<Believer> getBeliever() {
return believer;
}
从表(Believer)
private God god;
public void setGod(God god){
this.god= god;
}
@ManyToOne(cascade = {}, fetch = FetchType.LAZY)
@JoinColumns({
@JoinColumn(name = "godid",nullable = false, insertable = false, updatable = false)
})
public God getGod() {
return god;
}
这里我只是我自己的理解,上面两个链接说的很详细,希望大家能给出一些宝贵建议!谢谢!
分享到:
相关推荐
@OneToMany(mappedBy = "user") private List<Role> roles; // ... } @Entity public class Role { @Id private Long id; @ManyToOne @JoinColumn(name = "user_id") private User user; // ... } ``` ...
`mappedBy`属性指定了关联的反向属性名称,表示`EntityB`中的哪个属性与`EntityA`相关联。 2. **双向关联**: 双向关联意味着在双方实体中都定义了`@OneToOne`注解。例如,在`EntityA`和`EntityB`中: ```java ...
@OneToMany(mappedBy = "user") private List<Order> orders; // ... } @Entity public class Order { @Id private Long id; @ManyToOne @JoinColumn(name = "USER_ID") private User user; // ... } ``...
在上面的代码中,`Person`类中的`profile`属性使用了`mappedBy`属性,表明`Profile`是被关联方,`Profile`类中的`person`属性则使用了`@OneToOne`和`@PrimaryKeyJoinColumn`注解,表示`Person`是关联方,且主键和...
`mappedBy`属性用于指定被引用方的属性名。 - **一对多关联 (@OneToMany)**: 表示一个实体可以关联多个其他实体。`@JoinColumn`用于指定外键所在的列,`fetch = FetchType.LAZY`控制加载策略,可选择懒加载或立即...
@OneToMany(mappedBy = "user") private List<Role> roles; } @Entity @Table(name = "roles") public class Role { // ... @ManyToOne @JoinColumn(name = "user_id") private User user; } ``` 七、懒...
这里,`mappedBy`属性在`User`类中指定了`orders`字段,这意味着`Order`类中的`user`字段是关系的“所有者”。`@JoinColumn`则定义了外键字段名,这里是`user_id`,它将被创建在`Order`表中。 当我们保存`User`对象...
@OneToMany(mappedBy = "user") private List<Order> orders; } @Entity @Table(name = "orders") public class Order { // ... @ManyToOne @JoinColumn(name = "user_id") private User user; } ``` ### 6...
@OneToMany(mappedBy = "user") private List<Order> orders; } @Entity public class Order { @ManyToOne @JoinColumn(name = "USER_ID") private User user; } ``` 这里,`orders`字段表示用户的一对多关系...
本文将深入探讨Hibernate Annotation,帮助读者理解和掌握这一强大的工具。 一、Hibernate Annotation基础 1.1 Entity注解:在Java类上使用@Entity标记,表示该类是一个实体类,与数据库中的表相对应。例如: ```...
例如,在`Teacher`类中,我们可以定义一个`List<Student>`类型的字段,并使用`@OneToMany(mappedBy = "teacher")`来指定学生实体中的反向引用字段,如`@ManyToOne`注解的`teacher`属性。`mappedBy`属性用于指示关联...
本教程将深入探讨如何在Hibernate中使用注解(Annotation)进行配置,从而避免传统的XML配置文件。通过这种方式,我们可以更直观地将数据库表与Java实体类关联起来。 首先,让我们理解什么是Hibernate注解。...
@OneToMany(mappedBy = "user", cascade = CascadeType.ALL) @OrderBy("created DESC") private List<Order> orders; // getters and setters } ``` 总结,Hibernate注解提供了更直观、简洁的ORM解决方案,...
@OneToMany(mappedBy = "user", cascade = CascadeType.ALL) private List<Order> orders; ``` 这表示当用户对象被保存或删除时,关联的订单列表也会进行相应的操作。 7. **索引和唯一性约束(@Index, @...
使用Hibernate的注解,开发者可以更直观地理解对象与数据库的关系,并减少XML配置的工作量。然而,虽然注解简化了配置,但在大型项目中,混合使用注解和XML配置可能是更好的选择,以保持灵活性和可维护性。在实际...
Hibernate Annotation是一套用于声明式地配置Java持久化对象与数据库表之间映射关系的注解API,它属于Hibernate框架的一部分。在处理一对多关系时,Hibernate Annotation提供了便捷的方式来表达实体之间的关联。本文...
@OneToMany(mappedBy = "user") private List<Role> roles; } @Entity public class Role { @ManyToOne @JoinColumn(name = "USER_ID") private User user; } ``` 4. **继承策略**:Hibernate支持单表...
对于一对多的双向映射,如果要一对多这一端维护关联关系,你需要删除mappedBy元素并将多对一这端的@JoinColoumn的insertable和updatabel设置为false。这种方案不会得到什么明显的优化,而且还会增加一些附加的UPDATE...
**正文** Hibernate是一款强大的Java持久化框架,它简化了数据库操作,使得...在提供的"HibernateAnnotation"压缩包文件中,应该包含了一些具体的注解配置示例,这将帮助你更深入地了解和掌握Hibernate的注解配置。