把“ai.setOwnerNo(people)”注解了试试,由于 AutoInfo 没有主动维护关系,导致 AUTO_INFO 表中 OWNER_NO 字段为“Null”。自然 AutoInfo 与 Poople 就不存在任何联系了。
人类的求知欲很强烈!
为什么非要用 AutoInfo 作为主控方?People 作主控方不行?好吧,为 People.hbm.xml 删除inverse=”true”,再运行以上程序,其实也能保存,只是多了一条SQL:“update auto_info set OWNER_NO=? where AUTO_ID=?”,这就是 AutoInfo 被动地修改和 People 的联系。多执行一次 SQL 意味着多了一些开销,这是对性能不利的!
《我的 O/R Mapping 之旅(三)》,有一段对张三第二次买车的程序和描述:
AutoInfo ai = new AutoInfo();
People people = new People();
public void DoTest() {
try {
Configuration cfg = new Configuration().configure();
SessionFactory sessions = cfg.buildSessionFactory();
Session session = sessions.openSession();
Transaction tx = session.beginTransaction();
people =
(People) session
.find(
"from People where OWNER_ID=1")
.get(0);
ai.setLicensePlate("A00002");
ai.setOwnerNo(people);
people.getAutoInfoSet().add(ai);
session.save(people);
tx.commit();
session.close();
} catch (Exception e) {
System.out.println(e);
}
}
《我的 O/R Mapping 之旅(四)》,删除 PEOPLE 表及其关联的 AUTO_INFO 表时,程序是没有错,不过有更简单的办法来删除:
try {
Configuration cfg = new Configuration().configure();
SessionFactory sessions = cfg.buildSessionFactory();
Session session = sessions.openSession();
Transaction tx = session.beginTransaction();
session.delete("from People where OWNER_ID=1");
tx.commit();
session.close();
} catch (Exception e) {
System.out.println(e);
}
Hibernate 中,要完成一次操作,可以有多种实现方式,哪种最好,就要靠自己定夺了。
(请注意!引用、转贴本文应注明原作者:Rosen Jiang 以及出处:http://blog.csdn.net/rosen)
本文地址:http://com.8s8s.com/it/it12436.htm