many2many 单向

本文介绍使用Hibernate实现多对多关系的两种方式:通过注解和XML配置。包括Student和Teacher实体类的设计,以及如何定义它们之间的关联。
@Entity
public class Student {
	private int id;
	private String name;
	public Student() {
		super();
		// TODO Auto-generated constructor stub
	}
	@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
public class Teacher {
	private int id;
	private String name;
	private Set<Student> students=new HashSet<Student>();
	
	@ManyToMany
	@JoinTable(name="t_s",
			joinColumns=@JoinColumn(name="t_teacher"),
			inverseJoinColumns=@JoinColumn(name="t_student"))
	public Set<Student> getStudents() {
		return students;
	}

	public void setStudents(Set<Student> students) {
		this.students = students;
	}

	@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;
	}

	public Teacher() {
		super();
		// TODO Auto-generated constructor stub
	}
}

上面是 annocation的

接着是xml的

 

<hibernate-mapping package="com.sl.many2many">
	<class name="Student">
		<id name="id" column="s_id">
			<generator class="native" />
		</id>
		<property name="name" column="s_name"/>
	</class>
</hibernate-mapping>


 

<hibernate-mapping package="com.sl.many2many">
	<class name="Teacher">
		<id name="id" column="t_id">
			<generator class="native" />
		</id>
		<property name="name" column="t_name"/>
		<set name="students" table="s_t">
			<key column="teacherID"></key>
			<many-to-many column="studentID" class="Student"></many-to-many>
		</set>
	</class>
</hibernate-mapping>


 

 


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值