獲取Hibernate關(guān)聯(lián)關(guān)系的方法
作者:佚名
這里介紹獲取Hibernate關(guān)聯(lián)關(guān)系的pojo。我是指例如一個User(用戶)擁有一個many-to-one的屬性Unit(單位),但是有時有些用戶的Unit屬性為空。
本文向大家介紹獲取Hibernate關(guān)聯(lián)關(guān)系的方法,可能好多人還不了解Hibernate關(guān)聯(lián)關(guān)系,沒有關(guān)系,看完本文你肯定有不少收獲,希望本文能教會你更多東西。
獲取Hibernate關(guān)聯(lián)關(guān)系的pojo。我是指例如一個User(用戶)擁有一個many-to-one的屬性Unit(單位),但是有時有些用戶的Unit屬性為空,如果按單位查詢用戶的時候那些單位為null的用戶就會被遺漏,如何調(diào)取呢?這本來是很簡單的,但是我想當(dāng)然的使用了Restriction.eq,但是不行,后來看了手冊才發(fā)現(xiàn)應(yīng)該使用Restrictions.isNul。
下面是Test代碼:
- public void getUsersWhosUnitIsNullByRestrictionsEqNullUnit() {
- DetachedCriteria dc = DetachedCriteria.forClass(User.class);
- dc.add(Restrictions.eq("unit", null));
- Criteria cri = dc.getExecutableCriteria(session);
- log.debug("getUsersWhosUnitIsNullByRestrictionsEqNullUnit():" + cri.list().size());
- }
- /** *//**
- * 為了獲取一個unit為null的用戶,如果傳入一個id為null的Unit實例則會報錯,無法翻譯為SQL
- * 錯誤類型為:org.hibernate.TransientObjectException
- * 這也不是我們所期望的結(jié)果
- */
- @Ignore
- @Test(expected=TransientObjectException.class)
- public void getUsersWhosUnitIsNullByRestrictionsEqUnitNullId() {
- Unit unit = new Unit();
- log.debug(unit.getId());
- DetachedCriteria dc = DetachedCriteria.forClass(User.class);
- dc.add(Restrictions.eq("unit", unit));
- Criteria cri = dc.getExecutableCriteria(session);
- log.debug("getUsersWhosUnitIsNull():" + cri.list().size());
- }
- /** *//**
- * 為了獲取一個unit為null的用戶正確的方法應(yīng)該是使用Restrictions.isNull方法
- * 因為執(zhí)行的SQL為:(select * ) from USER_INF this_ where this_.UNIT_ID is null
- * 這才是我們所希望的結(jié)果
- */
- @Test
- public void getUsersWhosUnitIsNullByRestrictionsIsNull() {
- DetachedCriteria dc = DetachedCriteria.forClass(User.class);
- dc.add(Restrictions.isNull("unit"));
- Criteria cri = dc.getExecutableCriteria(session);
- log.debug("getUsersWhosUnitIsNullByRestrictionsIsNull():" + cri.list().size());
- }
以上介紹獲取Hibernate關(guān)聯(lián)關(guān)系的方法。
【編輯推薦】
責(zé)任編輯:佚名
來源:
51CTO.com