码迷,mamicode.com
首页 > 移动开发 > 详细

谈 Hibernate Annotation @mappedBy含义

时间:2015-01-21 13:20:35      阅读:150      评论:0      收藏:0      [点我收藏+]

标签:

“一对多/多对一”是数据库表关系中最常见的一种关系。两张表通过外键进行关联,实现表达“一对多/多对一”关系。外键通常位于”多方”表中。

用学生选课的例子 来说一下自己对这个注释@mappedBy的理解。

关系:

学生Student 多方--------课程Course 多方

学生 Student多方--------老师 Teacher一方

mappedBy 指向的是放弃维护关系的一方。 学生与课程,即课程类放弃维护关系,外键在Student类中。学生与老师,即老师Teacher放弃维护关系,外键在学生Student类中。

@Entity
@Table(name="t_student")
public class Student {
    @Id
    @GeneratedValue
    private Integer id; //主键Id
    private String uname; //学生名字
    private String pwd;// 密码
    private String phone;//手机号码 
    private String email;//邮箱
    
    /*
     * 外键通常放在 多方表中,放在学生表中.course放弃维护
     */
    @ManyToMany
    private Set<Course> courses = new HashSet<Course>();
    
    @ManyToOne
    private Teacher teacher;
@Entity
@Table(name="t_course")
public class Course {
    @Id
    @GeneratedValue
    private Integer id; 
    private String courseDesc;//课程描述
    private String courseNo;//课程代号
    
    //Course放弃 维护外键。
    @ManyToMany(mappedBy="courses")
    private Set<Student>students= new HashSet<Student>();
@Entity
@Table(name="t_teacher")
public class Teacher {
    @Id
    @GeneratedValue
    private Integer id;
    private String name;//姓名
    private String pwd;//密码
    private String phone;//手机
    
    
    /*
     * 外键一般放在 多方表中.
     * mappedBy  指向的是  放弃  维护  关系的类.即,Teacher 类 放弃 维护关系 ,外键 放在Student类中,让学生来维护 。
     */
    @OneToMany(mappedBy="teacher")
    private Set<Student>students = new HashSet<Student>();

 技术分享数据库表单

技术分享course类表单

技术分享学生类表单

技术分享学生 -老师关系表

谈 Hibernate Annotation @mappedBy含义

标签:

原文地址:http://www.cnblogs.com/shuanlei/p/4238453.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!