项目中有两张表,一张角色和机构的关系表role_work_site_relation,存放的是机构的id和角色的id,另一张表member_info表中存放用户相关信息。机构为树形结构,role_work_site_relation中存放的是当前角色中的所有机构id。查询member_info时需要根据role_work_site_relation查询到有权限的相应机构下的数据。而member_info中存放的机构id是包含其父级机构的。需要再查询时,首先查出所有的最低一级机构,再根据id到用户表中模糊匹配,中间需要用or拼接。sql语句类似于:SELECT * FROM member_info WHERE 得了= 0 AND ( memberinfo0_.ORG_IDS LIKE ? OR memberinfo0_.ORG_IDS LIKE ?..)。
sql语句如下:
//查询工地 搜索框有内容时
if (!StrUtil.isEmptyIfStr(conditions.get("orgIds"))){
predicate1.getExpressions().add(criteriaBuilder.equal(root.get("orgIds"), conditions.get("orgIds")));
// 搜索框没有内容时,查询是当前角色下的机构
}else {
//以or拼接工地的id集合
if (bottomLevelDataPermission.size() > 0){
List predicateList = new ArrayList();
Predicate [] p = new Predicate[bottomLevelDataPermission.size()];
for (String dataPermission : bottomLevelDataPermission) {
predicateList.add(criteriaBuilder.like(root.get("orgIds"),"%" + dataPermission));
}
predicateList.toArray(p);
predicate1.getExpressions().add(criteriaBuilder.or(p));
}
}
//根据工地id查询用户相关信息
if (!StrUtil.isEmptyIfStr(conditions.get("workSite"))) {
predicate.getExpressions().add(criteriaBuilder.equal(root.join("workSite").get("id"),conditions.get("workSite")));
}