hibernate使用注解实现多对多关联映射

这里使用学生选课作为例子。学生可以选择多门课程,一门课程可以被多个学生选择。有三个表,学生表、课程表、学生与课程关系的关联表。
学生


@Entity
@Table(name="student")
public class Student implements Serializable{
    @Transient
    private static final long serialVersionUID = 1L;

    @Id
    @Column(name="studentid")
    @GeneratedValue(strategy=GenerationType.IDENTITY)//定义主键生成策略,不写的话中间表可能没有真实数据
    private int studentid;

    @Column(name="name")
    private String name;

    @Column(name="sex")
    private String sex;
    /**
     * @ManyTOMany多对多映射
     * @JoinTable添加关联表(name="关联表表名",joincolumns={@joincolumn(name="关联表外键字段名",referencedColumnName="主表的主键字段名")})
     */
    @ManyToMany
    @Cascade(org.hibernate.annotations.CascadeType.SAVE_UPDATE)
    @JoinTable(name="student_course",
        joinColumns={@JoinColumn(name="studentid",referencedColumnName="studentid")},
        inverseJoinColumns={@JoinColumn(name="courseid",referencedColumnName="id")})
/*
省略setter、getter
*/

课程

@Entity
@Table(name="course")
public class Course implements Serializable{
    @Transient
    private static final long serialVersionUID = 1L;

    @Id
    @Column(name="id")
    private int courseid;

    @Column(name="coursename",nullable=false,unique = true)
    private String coursename;
    @Column
    private String isRequired;
    public String getIsRequired() {
        return isRequired;
    }

    public void setIsRequired(String isRequired) {
        this.isRequired = isRequired;
    }

    @ManyToMany(mappedBy="courses")//由学生端维护中间表
    /*@JoinTable(name="student_course",
        joinColumns={@JoinColumn(name="courseid",referencedColumnName="id")},
        inverseJoinColumns={@JoinColumn(name="studentid",referencedColumnName="studentid")})
        两端都可以维护中间表*/
    private List<Student> students;
/*
省略setter、getter
*/
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值