Spring+Hibernate3的框架中用到了關(guān)聯(lián)查詢
表User:Address是一對(duì)多的關(guān)系
UserBean中有一個(gè)addresses的Set
現(xiàn)在要查詢出這樣的User,擁有Address中門牌doorplate為"642"的User,
現(xiàn)在DB中只有一個(gè)這樣的User,這個(gè)User擁有門牌doorplate為"642"的Address五個(gè)~~
創(chuàng)建DetachedCriteria 的語(yǔ)句如下:
DetachedCriteria detachedCriteria = DetachedCriteria.forClass(User.
class);
detachedCriteria.createCriteria(
"才").add(Restrictions.like("doorplate","642"));
實(shí)際查詢語(yǔ)句如下:
List list = getHibernateTemplate().findByCriteria(queryCriteria);
理論上查詢出來(lái)的list應(yīng)該User的list是1
總結(jié)如下
1:
DetachedCriteria addressCriteria = DetachedCriteria.forClass(User.class).createCriteria("addresses");
addressCriteria.add(Restrictions.eq("doorplate","642")):
2:
DetachedCriteria addressCriteria = DetachedCriteria.forClass(User.class).createAlias("addresses", "a");
addressCriteria.add(Restrictions.eq("a.doorplate","642")):
posted on 2006-10-20 11:10
★yesjoy★ 閱讀(5801)
評(píng)論(4) 編輯 收藏 所屬分類:
Hibernate學(xué)習(xí)