这个关系,t1教s1,s2,t2教s1,s2,然后写出CRUD
先写两个类Student.java
@Entity
public class Student {
private String name;
private int id;
private Set<Teacher>teachers=new HashSet<Teacher>();
@ManyToMany(mappedBy="students")
public Set<Teacher> getTeachers() {
return teachers;
}
public void setTeachers(Set<Teacher> teachers) {
this.teachers = teachers;
}
@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;
}
}
Teacher.java
@Entity
public class Teacher
{
private Set<Student>students=new HashSet<Student>();
private String name;
private int id;
public void setStudents(Set<Student> students) {
this.students = students;
}
@ManyToMany(cascade = {CascadeType.ALL} )
public Set<Student> getStudents() {
return students;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
}
测试类
保存数据:
SessionFactory sf=null;
@Before
public void before()
{
AnnotationConfiguration cfg=new AnnotationConfiguration().configure();
new SchemaExport(cfg).create(false, true);
sf=cfg.buildSessionFactory();
}
@After
public void after()
{
sf.close();
}
@Test
public void TestSave()
{
Session sess=sf.getCurrentSession();
sess.beginTransaction();
Teacher t1=new Teacher();
t1.setName("t1");
Teacher t2=new Teacher();
t2.setName("t2");
Student s1=new Student();
s1.setName("s1");
Student s2=new Student();
s2.setName("s2");
t1.getStudents().add(s1);
t1.getStudents().add(s2);
t2.getStudents().add(s1);
t2.getStudents().add(s2);
sess.save(t1);
sess.save(t2);
sess.getTransaction().commit();
}
读取数据
@Test
public void TestRead()
{
TestSave();
Session sess=sf.getCurrentSession();
sess.beginTransaction();
Teacher teacher=(Teacher)sess.load(Teacher.class, 1);
for(Student s:teacher.getStudents())
{
System.out.println(s.getName());
}
sess.getTransaction().commit();
}
更新数据
@Test
public void TestUpdate()
{
TestSave();
Session sess=sf.getCurrentSession();
sess.beginTransaction();
Student stu=(Student)sess.load(Student.class, 1);
stu.setName("s3");
sess.getTransaction().commit();
}
删除数据 将 s1 从 t1 那里删除
@Test
public void TestDelete()
{
TestSave();
Session sess=sf.getCurrentSession();
sess.beginTransaction();
Student stu=(Student)sess.load(Student.class, 1);
Teacher t1=(Teacher)sess.load(Teacher.class, 1);
t1.getStudents().remove(stu);
stu.getTeachers().remove(t1);
sess.getTransaction().commit();
}