trl20121212
trl20121212
2016-01-22 16:26
采纳率: 33.3%
浏览 2.1k
已采纳

Hibernate 语句执行顺序问题

代码:
private static void editInfo() {
    Session session = null;
    try {
        session = HibernateUtil.getSession();
        if (session != null) {
            session.beginTransaction();
            Person p = new Person("王三", 22, "男", "北京");
            session.save(p);
            session.delete(p);
            p.setId(null);
            session.save(p);
            session.getTransaction().commit();
        }
    } catch (Exception ex) {
        if (session != null) {
            session.getTransaction().rollback();
        }
        ex.printStackTrace();
    } finally {
        HibernateUtil.CloseSession();
    }
}
控制台显示:
Hibernate: 
insert 
into
    PERSON
    (NAME, AGE, GENDER, ADDRESS) 
values
    (?, ?, ?, ?)

Hibernate:
delete
from
PERSON
where
ID=?
Hibernate:
insert
into
PERSON
(NAME, AGE, GENDER, ADDRESS)
values
(?, ?, ?, ?)

按照Hibernate的规定执行应该是insert,insert,delete,但不知道为什么这里是insert,delete,insert,请各位大哥指教一下。
  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • u010876380
    JAVA小皇帝 2016-01-22 17:36
    已采纳

    数据库执行sql时,遵循事务原则。按照你的程序执行顺序就应该是save(insert)、delete、save(insert)呀。还有你的ID难道不是唯一的吗?为什么能设置为空很难理解。

    点赞 评论
  • caozhy

    session.getTransaction().commit();才会真正执行挂起的数据库操作,之前的操作会产生一个变更集,但是不会记录它们被调用的顺序,所以最后的顺序是不可知的。

    点赞 评论
  • a8761087
    GrowingDarker 2016-01-23 11:24

    和hibernate无关啊,就按代码顺序执行。

    点赞 评论

相关推荐