17。多:多映射

1.数据库中,使用中间表完成多:多关联。

2.类图中,单向导航,在”导航“类中使用@ManyToMany即可。

3.双向导航:分别在导航类中使用@ManyToMany,并选择其中一个使用(mappedBy)或@Transient

单向例子:student和teacher。

需求:student可以找到教他的所有老师。而老师不必找到他教的学生。

Student.java

@Entity
@Table(name = "t_student")
public class Student {
    private Set<Teacher> teacher = new HashSet<Teacher>();
    private int id;
    private String name;

    @ManyToMany
    //设置中间表的列名    
    @JoinTable(name = "s_t", joinColumns = { @JoinColumn(name = "studentID") }, inverseJoinColumns = { @JoinColumn(name = "teacherID") })
    public Set<Teacher> getTeacher() {
        return teacher;
    }

    @Id
    @GeneratedValue
    public int getId() {
        return id;
    }

Teacher表不需要导航到Student,自然就不用标注任何注解了。

但是,如果Teacher类需要导航到Student,那么就要在Teacher中加注解:@transient或者@ManyToMany(mappedBy=”teacher”);

@Entity
@Table(name="t_teacher")
public class Teacher {
    private int id;
    private String name;
    private Set<Student> student = new HashSet<Student>();
    
    @Id
    @GeneratedValue
    public int getId() {
        return id;
    }
    public String getName() {
        return name;
    }
    //@Transient      
    
    public Set<Student> getStudent() {
        return student;
    }

转载于:https://www.cnblogs.com/honbaa/p/3369445.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值