From 086e24d444fbd660228e358802969902fe857f23 Mon Sep 17 00:00:00 2001
From: fengxiang <110431245@qq.com>
Date: Thu, 27 Sep 2018 09:13:17 +0800
Subject: [PATCH] device编辑后 删除 redis里 device_*****记录
---
src/main/java/com/moral/service/impl/OrganizationServiceImpl.java | 70 +++++++++++++++++++++++++++++++++-
1 files changed, 67 insertions(+), 3 deletions(-)
diff --git a/src/main/java/com/moral/service/impl/OrganizationServiceImpl.java b/src/main/java/com/moral/service/impl/OrganizationServiceImpl.java
index 92e9a0c..2dca7d1 100644
--- a/src/main/java/com/moral/service/impl/OrganizationServiceImpl.java
+++ b/src/main/java/com/moral/service/impl/OrganizationServiceImpl.java
@@ -10,12 +10,15 @@
import com.moral.mapper.OrganizationMapper;
import com.moral.mapper.OrganizationRelationMapper;
import com.moral.service.OrganizationService;
+import org.apache.commons.collections.CollectionUtils;
+import org.springframework.data.annotation.Transient;
import org.springframework.stereotype.Service;
import tk.mybatis.mapper.entity.Example;
import tk.mybatis.mapper.entity.Example.Criteria;
import javax.annotation.Resource;
import java.util.*;
+import java.util.stream.Collectors;
import static com.moral.common.bean.Constants.IS_DELETE_FALSE;
@@ -40,7 +43,7 @@
if (IS_DELETE_FALSE.equals(organization.getIsDelete())) {
List<OrganizationRelation> organizationRelations = organizationRelationMapper.select(relation);
for (OrganizationRelation organizationRelation : organizationRelations) {
- Set<Integer> organizationIds = getChildOrganizationIds(organizationRelation.getParentId());
+ Set<Integer> organizationIds = getChildOrganizationIds(organizationRelation.getChildId());
orgIds.addAll(organizationIds);
}
}
@@ -55,6 +58,7 @@
return organizations;
}
+ @Override
public PageBean queryByPageBean(PageBean pageBean){
Example example = ExampleUtil.generateExample(ENTITY_CLASS,pageBean);
List<Example.Criteria> criteriaList = example.getOredCriteria();
@@ -68,9 +72,13 @@
if(pageBean.getPageSize()>0){
PageHelper.startPage(pageBean.getPageIndex(),pageBean.getPageSize());
}
+ if(example.getOrderByClause() == null || example.getOrderByClause().isEmpty()) {
+ example.setOrderByClause("create_time desc");
+ }
List<Organization> organizationList = organizationMapper.selectWithAreaNameByExample(example);
return new PageBean(organizationList);
}
+ @Override
public void addOrModify(Organization organization){
try{
if(organization.getId()==null){
@@ -78,14 +86,49 @@
organization.setIsDelete(Constants.IS_DELETE_FALSE);
organizationMapper.insertSelective(organization);
}else{
- organizationMapper.updateByPrimaryKeySelective(organization);
+ organizationMapper.updateByPrimaryKey(organization);
}
+ //���������������������
+ addOrModifyOrgRelation(organization);
}
catch (Exception ex){
throw ex;
}
}
-
+ @Transient
+ private void addOrModifyOrgRelation(Organization organization){
+ OrganizationRelation relation = new OrganizationRelation();
+ relation.setChildId(organization.getId());
+ List<OrganizationRelation> relations = organizationRelationMapper.select(relation);
+ if(CollectionUtils.isEmpty(relations)){
+ relation.setParentId(organization.getParentId());
+ organizationRelationMapper.insert(relation);
+ }else{
+ OrganizationRelation relationOfSelect = relations.get(0);
+ //���������������������������������������
+ if(organization.getParentId() !=null &&
+ !organization.getParentId().equals(relationOfSelect.getParentId())
+ ) {
+ relationOfSelect.setParentId(organization.getParentId());
+ organizationRelationMapper.updateByPrimaryKey(relationOfSelect);
+ }else if(organization.getParentId() ==null){
+ //ParentI���null���������������������
+ organizationRelationMapper.deleteByPrimaryKey(relationOfSelect.getId());
+ }
+ //������������������
+ if(relations.size()>1){
+ relations.remove(0);
+ List<Integer> relationIds = relations.stream().map(
+ element->{
+ return element.getId();
+ }
+ ).collect(Collectors.toList());
+ Example example = new Example(OrganizationRelation.class);
+ example.or().andIn("id",relationIds);
+ organizationRelationMapper.deleteByExample(example);
+ }
+ }
+ }
@Override
public void deleteByIds(Integer... ids) {
Organization organization = new Organization();
@@ -116,4 +159,25 @@
return organizations;
}
+ @Override
+ public Organization getOrganizationById(int id) {
+ Example example = new Example(ENTITY_CLASS);
+ example.or().andEqualTo("id",id);
+ List<Organization> organizationList = organizationMapper.selectWithAreaNameByExample(example);
+ return organizationList.size()>0?organizationList.get(0):null;
+ }
+
+ @Override
+ public Organization getFatherOrg(int childId) {
+ OrganizationRelation relation = new OrganizationRelation();
+ relation.setChildId(childId);
+ List<OrganizationRelation> relations = organizationRelationMapper.select(relation);
+ if (!CollectionUtils.isEmpty(relations)){
+ OrganizationRelation relationOfSelect = relations.get(0);
+ if(relationOfSelect.getParentId()!=null){
+ return organizationMapper.selectByPrimaryKey(relationOfSelect.getParentId());
+ }
+ }
+ return null;
+ }
}
--
Gitblit v1.8.0