JPA 多表动态查询

 示例一:

@PersistenceContext
EntityManager entityManager;    
public List<Map<String, Object>> getStudentInfo(String idOrName,Integer province,Integer city,Integer area) {
        StringBuilder sql = new StringBuilder("select s.id,s.name,s.sex,s.sid,s.health,s.grade,s.birthday,c.cname,sp.name as spname,d.name as dname,q.virtue,q.intelligence,q.social,q.art from student s join classes c on s.bid = c.cid join speciality sp on c.zid = sp.id left join department d on sp.did = d.id left join quality q on s.sid = q.sid where (s.sid=:idOrName or s.name=:idOrName)");
        Map<String,Object> params = new HashMap<>();
        params.put("idOrName",idOrName);
        if (!StringUtils.isEmpty(province)){
            sql.append(" and d.id=:province");
            params.put("province",province);
        }
        if (!StringUtils.isEmpty(city)){
            sql.append(" and sp.id=:city");
            params.put("city",city);
        }
        if (!StringUtils.isEmpty(area)){
            sql.append(" and c.cid=:area");
            params.put("area",area);
        }
//unwrap(NativeQueryImpl.class).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
//用于处理返回结果ALIAS_TO_ENTITY_MAP可以将查询用实体类或者map来接收
        Query nativeQuery = entityManager.createNativeQuery(sql.toString()).unwrap(NativeQueryImpl.class).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
        //查询参数填充
        for (Map.Entry<String,Object> param:params.entrySet()){
            nativeQuery.setParameter(param.getKey(),param.getValue());
        }
        //获取结果集
        List<Map<String, Object>> res  = nativeQuery.getResultList();
        return res;
    }

示例二:

对于in 关键词的使用:jpa可以直接传入集合

 public  List<Student> testEntity(List<Integer> ids){
        StringBuilder sql = new StringBuilder("select * from student where bid in :ids");
        //用实体类接收也可以写成这样简单的方式
        //Query nativeQuery = entityManager.createNativeQuery(sql.toString(),Student.class);
        Query nativeQuery = entityManager.createNativeQuery(sql.toString()).unwrap(NativeQueryImpl.class).setResultTransformer(Transformers.Transformers.ALIAS_TO_ENTITY_MAP);
        nativeQuery.setParameter("ids",ids);
        List<Student> students = nativeQuery.getResultList();
        return students;
    }

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值