SpringData JPA动态拼接sql语句实现动态的多表条件查询

 
 @Autowired
 private EntityManager entityManager;

public List<Object[]> findSignFileAndPosition(int pageNum, TbSignFile search) {
        PageRequest pageRequest = new PageRequest(pageNum, 10);

        StringBuffer sql = new StringBuffer("SELECT sf.file_code, sup.type " +
                "FROM tb_sign_file sf LEFT JOIN tb_sign_user_position sup " +
                "ON sf.file_code = sup.file_id " +
                "where 1=1 ");

        Map<String, Object> map = new HashMap<String, Object>();
        int i = 1;
        if (StringUtils.isNotBlank(search.getFileType())) {
            sql.append(" and sf.file_type=");
            sql.append("?" + i);
            map.put(i + "", search.getFileType());
            i++;
        }

        if (StringUtils.isNotBlank(search.getSignerType())) {
            sql.append(" and sf.signer_type=");
            sql.append("?" + i);
            map.put(i + "", search.getSignerType());
            i++;
        }
        if (StringUtils.isNotBlank(search.getSignMethod())) {
            sql.append(" and sf.sign_method=");
            sql.append("?" + i);
            map.put(i + "", search.getSignMethod());
            i++;
        }

        if (StringUtils.isNotBlank(search.getStatus())) {
            sql.append(" and sf.status=");
            sql.append("?" + i);
            map.put(i + "", search.getStatus());
            i++;
        }

        sql.append(" order by sf.update_time desc");

        String sqlStr = sql.toString();

        String count = "SELECT count(1) ";
        String substring = sqlStr.substring(0, sql.indexOf("FROM"));

        String countSql = sqlStr.replace(substring, count);

        Query query = entityManager.createNativeQuery(sqlStr);
        Query countQuery = entityManager.createNativeQuery(countSql);

        for (String key : map.keySet()) {
            query.setParameter(key, map.get(key));
            countQuery.setParameter(key, map.get(key));
        }

        query.setFirstResult((pageNum -1) * 10);
        query.setMaxResults(10);

        long total = ((BigInteger)countQuery.getSingleResult()).longValue();
        List list = query.getResultList();
        return list;

    }

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值