首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 网页设计 | 平面设计 | 技术专题 | 电子书下载 | 教学视频 | 源码下载 | 搜索 | 博客 | 论坛
中国IT实验室Linux频道
中国IT教育
Google
首页 资讯动态 认证考试 新手入门 核心技术 高级技术 J2EE J2ME Java&XML 开源技术 其他技术 RSS订阅 论坛 专题
您现在的位置: 中国IT实验室 >> Java >> 开源技术 >> Hibernate >> 正文

hibernate中获取关联属性为null的方式

    在Hibernate中获取有关联关系的pojo。我是指例如一个User(用户)拥有一个many-to-one的属性Unit(单位),但是有时有些用户的Unit属性为空,如果按单位查询用户的时候那些单位为null的用户就会被遗漏,如何调取呢?这本来是很简单的,但是我想当然的使用了Restriction.eq,但是不行,后来看了手册才发现应该使用Restrictions.isNul。下面是Test代码...

    /**
     * 为了获取一个unit为null的用户,如果传入一个null作为Uint实例则返回的结果总是0
     * 因为执行的SQL为:(select * ) from USER_INF this_ where this_.UNIT_ID=''
     * 这不是我们所期望的结果
     
*/

    @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
     * 这也不是我们所期望的结果
     
*/

    @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的用户正确的方法应该是使用Restrictions.isNull方法
     * 因为执行的SQL为:(select * ) from USER_INF this_ where this_.UNIT_ID is null
     * 这才是我们所希望的结果
     
*/

    @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());
    }
【责编:Peng】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·关于Java框架技术专题
 ·XML全攻略技术专题
 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性…
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题…
 ·展现C#世界 C#程序设计专题…
 ·Java入门 Tomcat的配置技巧精华专题…
 ·Oracle RMAN物理备份技术详解…
 今日更新
 社区讨论
 博客论点
 频道精选
 Java 频道导航