搜尋

首頁  >  問答  >  主體

java - hibernate:已经存在一个班级,已经存在多个学生,建立多个学生与班级之间的关系

hibernate问题
已经存在一个班级,已经存在多个学生,建立多个学生与班级之间的关系
这个怎么实现,请教各位大神
这是一个已经存在一个班级,已经存在一个学生,建立该班级与该学生之间的关系
@Test

public void testR_1() {
    Session session = sessionFactory.openSession();
    Transaction transaction = session.beginTransaction();
    Classes classes1 = (Classes) session.get(Classes.class, 1L);
    Student student = (Student) session.get(Student.class, 6L);
    classes1.getStudents().add(student);
    transaction.commit();
    session.close();
}

public class Classes implements Serializable {

private Long cid;
private String cname;
private String description;
private Set<Student> students;

public Long getCid() {
    return cid;
}

public void setCid(Long cid) {
    this.cid = cid;
}

public String getCname() {
    return cname;
}

public void setCname(String cname) {
    this.cname = cname;
}

public String getDescription() {
    return description;
}

public void setDescription(String description) {
    this.description = description;
}

public Set<Student> getStudents() {
    return students;
}

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

}

xml配置
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    <class name="com.liuyang.domain.Classes">
        <id name="cid" length="5" type="java.lang.Long">
            <generator class="increment"></generator>
        </id>
        <property name="cname" length="20" type="java.lang.String"></property>
        
        <property name="description" length="100" type="java.lang.String"></property>
        <!-- 
            set元素对应类中的set集合
            通过set元素使classes表与student表建立关联
               key是通过外键的形式让两张表建立关联
               one-to-many是通过类的形式让两个类建立关联
            
            cascade 级联
               save-update
                   1、当 保存班级的时候,对学生进行怎么样的操作
                        如果学生对象在数据库中没有对应的值,这个时候会执行save操作
                        如果学生对象在数据库中有对应的值,这个时候会执行update操作
               delete
               all
            inverse  维护关系
               true      不维护关系     
               false     维护关系
               default   false
         -->
        <set name="students" cascade="all">
            <!-- 
                key是用来描述外键
             -->
            <key>
                <column name="cid"></column>
            </key>
            <one-to-many class="com.liuyang.domain.Student"/>
        </set>
    </class>
</hibernate-mapping>

我是这么做的

11、已经存在一个班级,已经存在多个学生,建立多个学生与班级之间的关系
     */
    @Test
    public void testR_2() {
        Session session = sessionFactory.openSession();
        Transaction transaction = session.beginTransaction();
        Classes classes = (Classes) session.get(Classes.class, 2L);
        Set<Student> students = classes.getStudents();
        List<Student> sList = new ArrayList<Student>(students);
        for (int i = 0; i < sList.size(); i++) {
            if (sList.get(i).getSid().longValue() == 3
                    || sList.get(i).getSid().longValue() == 5) {
                sList.remove(sList.get(i));
                i--;
            }
        }
         students = new HashSet<Student>(sList);
         classes.setStudents(students);
         transaction.commit();
         session.close();
    }

但是只能查询到,无法加载更新,请教各位大神,如何处理,谢谢谢谢谢~~

PHP中文网PHP中文网2829 天前458

全部回覆(2)我來回復

  • 伊谢尔伦

    伊谢尔伦2017-04-18 10:17:29

    我有了100塊錢,有了一個不錯的想法,請問怎麼創業。

    回覆
    0
  • 天蓬老师

    天蓬老师2017-04-18 10:17:29

    不清楚想幹嘛?每個學生有1個班級id,這段關係不就有了?

    回覆
    0
  • 取消回覆