Hibernate 一對多自身關聯問題
這個很難描述清楚,只能引用CSDN中我提問的帖子了:
http://topic.csdn.net/u/20080711/16/7494bf10-48ca-4b2e-8a01-303e647f5516.html
方法,在表單中取得一個PO,然後session.save(po),如下:
程序代碼
tx = session.beginTransaction();
session.save(catalog);
tx.commit();
B方法,也是在表單取得一個PO,另外取得一個PO_ID,如下:
程序代碼
public void addChildCatalog(int id, Catalog c11) {
Catalog c1 = this.getCatalog(id);
log.info("c11.getId()::"+c11.getId());
c1.getChildCatalogs().add(c11);
c11.setParentCatalog(c1);
Session session = HibernateUtil.getSession();
Transaction tx = session.beginTransaction();
try {
session.save(c1);
session.save(c11);
tx.commit();
} catch (HibernateException e) {
if (tx != null) {
HibernateUtil.rollbackTransaction(tx);
}
} finally {
if (session != null) {
HibernateUtil.closeSession(session);
}
}
}
第一個功能,簡稱A功能,我是為了保存一個頂級菜單,沒任何關聯的。
第二個功能,B功能,我是為了根據那個父ID來做關聯保存。
現在出的問題是:我進入功能頁面,使用A功能,正常,再使用A功能,正常,很正常。。。使用N次都沒問題。
接著我使用B功能,不停的增加子類,也都正常。。。使用N次都很正常。
注意問題:當我使用過B功能之後,一切就變得不正常了,再使用A功能,相當於和使用B功能一樣,還是在做最後一次的B功能操作!加的是子分類。
另外問題:我只能不停的向下延伸子類,無法加入已有同級分類。比如
程序代碼
1級 id:1 c_id=null
2級 id:2 c_id=1
3級 id:3 c_id=2
假如數據庫中的關聯形式是這樣的,那麼我只能根據3的id,加入4級,不能在2級下面加入同級的3級類,如id:4 c_id=2;這樣的,我不能加入,控制台只有select操作,但是我可以加入id:4 c_id=3的。
最搞笑的是,當我把浏覽器關了,重開進入頁面,A功能正常了,加入同級id:4 c_id=2;也OK了,
接著我向下延伸分類,又出現了上述的問題,最讓我不理解的是,這跟浏覽器啥關系啊!(我的IE6,汗)
另外附上hbm.xml的關聯關系
程序代碼
<!-- self -->
<many-to-one name="parentCatalog"
class="com.blur.myHibernate.po.article.Catalog">
<column name="catalog_id"></column>
</many-to-one>
<set name="childCatalogs" cascade="save-update"
inverse="true" lazy="false">
<key>
<column name="catalog_id"></column>
</key>
<one-to-many
class="com.blur.myHibernate.po.article.Catalog" />
</set>
解決辦法:formBean在提交表單的時候,域中數據庫在下一次中仍然保留引起的,struts formBean 默認的scope為session,手動設置為request,就好了。。。