为了账号安全,请及时绑定邮箱和手机立即绑定

Session.save 抛出 TransientObjectException

Session.save 抛出 TransientObjectException

Helenr 2021-07-06 18:57:44
我有两个实体,名为student和course与ManyToMany 关系。正如我在这篇文章中读到的,我们可以调用 save 方法来保存事务中的相关实体,否则一旦会话被刷新,它就会被保存。我也理解导致此异常的典型级联问题,但在这里我也处理了它,但是我仍然在调用 save 方法时遇到 TransientObjectException 而persist 方法工作得很好。有人可以解释一下这里发生了什么吗?这是我的代码:SaveVsPersistTest.javapublic class SaveVsPersistTest {    public static void main(String[] args) {        // Create session factory object         SessionFactory sessionFactory = new Configuration()                .configure("hibernate.cfg.xml")                .addAnnotatedClass(Student.class)                .addAnnotatedClass(Course.class)                .buildSessionFactory();        Session session = sessionFactory.openSession();        Transaction transaction = session.beginTransaction();        Student student = new Student("Gopal");        Course course1 = new Course("Java");        Course course2 = new Course("C++");        student.addCourse(course1);        student.addCourse(course2);        session.save(student);        transaction.commit();        session.flush();    }}
查看完整描述

3 回答

?
吃鸡游戏

TA贡献1829条经验 获得超7个赞

正如其他人建议的那样,您可以在所有相关实体上显式调用 session.save,或者您可以使用 Hibernate 特定的@Cascade注释,如下所示。

@Cascade(CascadeType.SAVE_UPDATE)

cascade={CascadeType.ALL}在任何关联上使用的警告是,一旦您在父对象上调用 delete,您将删除所有子对象(或表中的行)。所以对此要谨慎一些。


查看完整回答
反对 回复 2021-07-14
?
慕丝7291255

TA贡献1859条经验 获得超6个赞

试试这个,它对我有用


Student s = new Student();

       s.setName("Gopal");

Course c1 = new Course();

       c1.setCourseTitle("courseTitle1");   

Course c2 = new Course();

       c2.setCourseTitle("courseTitle2");


// adding courses to student entity

 s. getCourseList().add(c1);

 s. getCourseList().add(c2);



// adding a student to courses.

 c1.getStudentList().add(s);

 c2.getStudentList().add(s);



 // saving all entities to DB.

     session.save(s);

     session.save(c1);

     session.save(c2);    


    transaction.commit();

    session.flush();


查看完整回答
反对 回复 2021-07-14
  • 3 回答
  • 0 关注
  • 158 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信