From e63b5ff9c4b734d1c6f988d341c99a2216f0564d Mon Sep 17 00:00:00 2001
From: 张天森 <1292933220@qq.com>
Date: 星期一, 17 十月 2022 18:06:19 +0800
Subject: [PATCH] 三说会堂事件操作权限处理

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/dao/ComMngPopulationDAO.java | 1582 +++++++++++++++++++++------------------------------------
 1 files changed, 590 insertions(+), 992 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/dao/ComMngPopulationDAO.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/dao/ComMngPopulationDAO.java
index f6c61ca..bb44fcd 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/dao/ComMngPopulationDAO.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/dao/ComMngPopulationDAO.java
@@ -1,9 +1,28 @@
 package com.panzhihua.service_community.dao;
 
+import java.util.Date;
+import java.util.List;
+import java.util.Map;
+
+import com.panzhihua.common.model.dtos.PageBaseDTO;
+import com.panzhihua.common.model.dtos.community.CascadeHouseDTO;
+import com.panzhihua.common.model.dtos.property.CommonPage;
+import com.panzhihua.common.model.vos.community.*;
+import com.panzhihua.common.model.vos.community.bigscreen.WestScreenStatics;
+import com.panzhihua.common.model.vos.community.screen.civil.*;
+import com.panzhihua.common.model.vos.community.bigscreen.BaseInfo;
+import com.panzhihua.common.model.vos.community.bigscreen.IndexDynamic;
+import com.panzhihua.service_community.model.dos.ComMngPopulationCommunityTagsDO;
+import org.apache.ibatis.annotations.Insert;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+import org.apache.ibatis.annotations.Select;
+
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.panzhihua.common.model.dtos.community.ComMngPopulationDTO;
+import com.panzhihua.common.model.dtos.community.bigscreen.BigScreenEventDTO;
 import com.panzhihua.common.model.dtos.grid.PageComMngPopulationDTO;
 import com.panzhihua.common.model.dtos.grid.PagePopulationListDTO;
 import com.panzhihua.common.model.dtos.grid.admin.ComMngPopulationExportDTO;
@@ -11,11 +30,6 @@
 import com.panzhihua.common.model.dtos.grid.admin.PageComMngVillagePopulationDTO;
 import com.panzhihua.common.model.dtos.user.PageInputUserDTO;
 import com.panzhihua.common.model.vos.area.AreaAddressVO;
-import com.panzhihua.common.model.vos.community.ComActMessageVO;
-import com.panzhihua.common.model.vos.community.ComMngPopulationTotalVO;
-import com.panzhihua.common.model.vos.community.ComMngPopulationVO;
-import com.panzhihua.common.model.vos.community.screen.civil.CivilPopulationStatisticsVO;
-import com.panzhihua.common.model.vos.community.screen.civil.CivilVillageStatisticsVO;
 import com.panzhihua.common.model.vos.community.screen.event.*;
 import com.panzhihua.common.model.vos.community.screen.index.*;
 import com.panzhihua.common.model.vos.grid.EventGridDataVO;
@@ -26,19 +40,7 @@
 import com.panzhihua.common.model.vos.grid.admin.ComMngVillagePopulationListVO;
 import com.panzhihua.common.model.vos.grid.admin.PopulationStatisticsVO;
 import com.panzhihua.common.model.vos.user.*;
-import com.panzhihua.common.model.vos.community.PageComActMessageVO;
-import com.panzhihua.common.model.vos.user.ComHouseMemberVo;
-import com.panzhihua.common.model.vos.user.ComMngFamilyInfoVO;
-import com.panzhihua.common.model.vos.user.InputUserInfoVO;
-import com.panzhihua.common.model.vos.user.UserElectronicFileVO;
 import com.panzhihua.service_community.model.dos.ComMngPopulationDO;
-import org.apache.ibatis.annotations.Mapper;
-import org.apache.ibatis.annotations.Param;
-import org.apache.ibatis.annotations.Select;
-
-import java.util.Date;
-import java.util.List;
-import java.util.Map;
 
 /**
  * 实有人口Dao
@@ -46,207 +48,136 @@
 @Mapper
 public interface ComMngPopulationDAO extends BaseMapper<ComMngPopulationDO> {
 
-    @Select("<script> " +
-            "SELECT " +
-            "cmp.`name`, " +
-            "cmp.id, " +
-            "cmp.street_id, " +
-            "cmp.act_id, " +
-            "cmp.village_id, " +
-            "cmp.sex, " +
-            "cmp.age, " +
-            "cmp.card_no, " +
-            "cmp.road, " +
-            "cmp.door_no, " +
-            "cmp.floor, " +
-            "cmp.unit_no, " +
-            "cmp.house_no, " +
-            "cmp.political_outlook, " +
-            "cmp.work_company, " +
-            "cmp.special_situation, " +
-            "cmp.phone, " +
-            "cmp.remark, " +
-            "cmv.alley, " +
-            "cmp.native_place, " +
-            "cmp.nation  " +
-            "FROM  " +
-            "com_mng_population AS cmp " +
-            "LEFT JOIN com_mng_village AS cmv ON cmv.village_id = cmp.village_id " +
-            "<where>" +
-            "<if test='comMngPopulationVO.name != null and comMngPopulationVO.name.trim() != &quot;&quot;'>" +
-            "AND cmp.`name` LIKE concat(#{comMngPopulationVO.name},'%') " +
-            " </if> " +
-            "<if test='comMngPopulationVO.road != null and comMngPopulationVO.road.trim() != &quot;&quot;'>" +
-            "AND cmp.road LIKE concat(#{comMngPopulationVO.road},'%') " +
-            " </if> " +
-            "<if test='comMngPopulationVO.doorNo != null and comMngPopulationVO.doorNo.trim() != &quot;&quot;'>" +
-            "AND cmp.door_no = #{comMngPopulationVO.doorNo} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.alley != null and comMngPopulationVO.alley.trim() != &quot;&quot;'>" +
-            "AND cmv.alley LIKE concat(#{comMngPopulationVO.alley},'%') " +
-            " </if> " +
-            "<if test='comMngPopulationVO.sex != null and comMngPopulationVO.sex.trim() != &quot;&quot;'>" +
-            "AND cmp.sex = #{comMngPopulationVO.sex} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.ageStart != null'>" +
-            "AND cmp.age <![CDATA[ >= ]]> #{comMngPopulationVO.ageStart} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.ageEnd != null'>" +
-            "AND cmp.age <![CDATA[ <= ]]> #{comMngPopulationVO.ageEnd} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.nativePlace != null and comMngPopulationVO.nativePlace.trim() != &quot;&quot;'>" +
-            "AND cmp.native_place LIKE concat(#{comMngPopulationVO.nativePlace},'%') " +
-            " </if> " +
-            "<if test='comMngPopulationVO.nation != null and comMngPopulationVO.nation.trim() != &quot;&quot;'>" +
-            "AND cmp.nation = #{comMngPopulationVO.nation} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.politicalOutlook != null and comMngPopulationVO.politicalOutlook.trim() != &quot;&quot;'>" +
-            "AND cmp.political_outlook = #{comMngPopulationVO.politicalOutlook} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.cardNo != null and comMngPopulationVO.cardNo.trim() != &quot;&quot;'>" +
-            "AND cmp.card_no = #{comMngPopulationVO.cardNo} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.remark != null and comMngPopulationVO.remark.trim() != &quot;&quot;'>" +
-            "AND cmp.remark = #{comMngPopulationVO.remark} " +
-            " </if> " +
-            " </where>" +
-            " order by cmp.create_at desc " +
-            "</script>")
+    @Select("<script> " + "SELECT " + "cmp.`name`, " + "cmp.id, " + "cmp.street_id, " + "cmp.act_id, "
+        + "cmp.village_id, " + "cmp.sex, " + "cmp.age, " + "cmp.card_no, " + "cmp.road, " + "cmp.door_no, "
+        + "cmp.floor, " + "cmp.unit_no, " + "cmp.house_no, " + "cmp.political_outlook, " + "cmp.work_company, "
+        + "cmp.special_situation, " + "cmp.phone, " + "cmp.remark, " + "cmv.alley, " + "cmp.native_place, "
+        + "cmphu.relation, " + "cmp.nation  " + "FROM  " + "com_mng_population AS cmp "
+        + "LEFT JOIN com_mng_village AS cmv ON cmv.village_id = cmp.village_id "
+        + "LEFT JOIN com_mng_population_house_user AS cmphu ON cmphu.popul_id = cmp.id " + "<where>"
+        + "<if test='comMngPopulationVO.name != null and comMngPopulationVO.name.trim() != &quot;&quot;'>"
+        + "AND cmp.`name` LIKE concat(#{comMngPopulationVO.name},'%') " + " </if> "
+        + "<if test='comMngPopulationVO.road != null and comMngPopulationVO.road.trim() != &quot;&quot;'>"
+        + "AND cmp.road LIKE concat(#{comMngPopulationVO.road},'%') " + " </if> "
+        + "<if test='comMngPopulationVO.doorNo != null and comMngPopulationVO.doorNo.trim() != &quot;&quot;'>"
+        + "AND cmp.door_no = #{comMngPopulationVO.doorNo} " + " </if> "
+        + "<if test='comMngPopulationVO.alley != null and comMngPopulationVO.alley.trim() != &quot;&quot;'>"
+        + "AND cmv.alley LIKE concat(#{comMngPopulationVO.alley},'%') " + " </if> "
+        + "<if test='comMngPopulationVO.sex != null and comMngPopulationVO.sex.trim() != &quot;&quot;'>"
+        + "AND cmp.sex = #{comMngPopulationVO.sex} " + " </if> " + "<if test='comMngPopulationVO.ageStart != null'>"
+        + "AND cmp.age <![CDATA[ >= ]]> #{comMngPopulationVO.ageStart} " + " </if> "
+        + "<if test='comMngPopulationVO.ageEnd != null'>" + "AND cmp.age <![CDATA[ <= ]]> #{comMngPopulationVO.ageEnd} "
+        + " </if> "
+        + "<if test='comMngPopulationVO.nativePlace != null and comMngPopulationVO.nativePlace.trim() != &quot;&quot;'>"
+        + "AND cmp.native_place LIKE concat(#{comMngPopulationVO.nativePlace},'%') " + " </if> "
+        + "<if test='comMngPopulationVO.nation != null and comMngPopulationVO.nation.trim() != &quot;&quot;'>"
+        + "AND cmp.nation = #{comMngPopulationVO.nation} " + " </if> "
+        + "<if test='comMngPopulationVO.politicalOutlook != null and comMngPopulationVO.politicalOutlook.trim() != &quot;&quot;'>"
+        + "AND cmp.political_outlook = #{comMngPopulationVO.politicalOutlook} " + " </if> "
+        + "<if test='comMngPopulationVO.cardNo != null and comMngPopulationVO.cardNo.trim() != &quot;&quot;'>"
+        + "AND cmp.card_no = #{comMngPopulationVO.cardNo} " + " </if> "
+        + "<if test='comMngPopulationVO.remark != null and comMngPopulationVO.remark.trim() != &quot;&quot;'>"
+        + "AND cmp.remark = #{comMngPopulationVO.remark} " + " </if> " + " </where>" + " order by cmp.create_at desc "
+        + "</script>")
     List<ComMngPopulationVO> listPopulation(ComMngPopulationDTO populationVO);
-
 
     @Select("select id,user_id,relationship,`name`,id_card,phone,age,health,job,create_at,update_at,card_photo_front,card_photo_back,family_book from com_mng_family_info where user_id=#{userId} order by create_at desc ")
     List<ComMngFamilyInfoVO> listFamilyByUserId(Long userId);
 
-    @Select("select cmphu.popul_id,cmp.name,cmp.relation,cmp.age,cmp.phone,cmp.healthy,cmp.card_no,cmp.work_company from com_mng_population_house_user cmphu " +
-            " left join com_mng_population cmp on cmp.id = cmphu.popul_id " +
-            " where cmphu.house_id = #{houseId} and cmphu.popul_id != #{populId}")
+    @Select("select cmphu.popul_id,cmp.name,cmp.relation,cmp.age,cmp.phone,cmp.healthy,cmp.card_no,cmp.work_company from com_mng_population_house_user cmphu "
+        + " left join com_mng_population cmp on cmp.id = cmphu.popul_id "
+        + " where cmphu.house_id = #{houseId} and cmphu.popul_id != #{populId}")
     List<ComHouseMemberVo> listHouseMermberByUserId(@Param("houseId") Long houseId, @Param("populId") Long populId);
 
-    @Select("<script> " +
-            "SELECT " +
-            "cmp.`name`, " +
-            "cmp.id, " +
-            "cmp.street_id, " +
-            "cmp.act_id, " +
-            "cmp.village_id, " +
-            "cmp.sex, " +
-            "cmp.card_no, " +
-            "cmp.road, " +
-            "cmp.door_no, " +
-            "cmp.floor, " +
-            "cmp.unit_no, " +
-            "cmp.house_no, " +
-            "cmp.political_outlook, " +
-            "cmp.work_company, " +
-            "cmp.special_situation, " +
-            "cmp.phone, " +
-            "cmp.remark, " +
-            "cmv.alley, " +
-            "cmp.native_place, " +
-            "cmp.nation,  " +
-            "cmp.label,  " +
-            "cmp.marriage,  " +
-            "cmp.culture_level,  " +
-            "cmp.out_or_local,  " +
-            "cmp.census_register,  " +
-            "cmp.healthy,  " +
-            "cmp.birthday,  " +
-            "cmp.update_at,  " +
-            "cmp.address,  " +
-            "cmp.is_rent  " +
-            "FROM  " +
-            "com_mng_population AS cmp " +
-            "LEFT JOIN com_mng_village AS cmv ON cmv.village_id = cmp.village_id " +
-            "<where>" +
-            "<if test='comMngPopulationVO.name != null and comMngPopulationVO.name != &quot;&quot;'>" +
-            "AND cmp.`name` LIKE concat(#{comMngPopulationVO.name},'%') " +
-            " </if> " +
-            "<if test='comMngPopulationVO.label != null and comMngPopulationVO.label != &quot;&quot;'>" +
-            "AND cmp.label LIKE concat('%',#{comMngPopulationVO.label},'%') " +
-            " </if> " +
-            "<if test='comMngPopulationVO.actId != null'>" +
-            " and cmp.act_id = #{comMngPopulationVO.actId} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.outOrLocal != null'>" +
-            " and cmp.out_or_local = #{comMngPopulationVO.outOrLocal} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.villageId != null'>" +
-            " and cmp.village_id = #{comMngPopulationVO.villageId} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.road != null and comMngPopulationVO.road != &quot;&quot;'>" +
-            "AND cmp.road = #{comMngPopulationVO.road} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.doorNo != null and comMngPopulationVO.doorNo != &quot;&quot;'>" +
-            "AND cmp.door_no = #{comMngPopulationVO.doorNo} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.floor != null and comMngPopulationVO.floor != &quot;&quot;'>" +
-            "AND cmp.floor = #{comMngPopulationVO.floor} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.unitNo != null and comMngPopulationVO.unitNo != &quot;&quot;'>" +
-            "AND cmp.unit_no = #{comMngPopulationVO.unitNo} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.houseNo != null and comMngPopulationVO.houseNo != &quot;&quot;'>" +
-            "AND cmp.house_no = #{comMngPopulationVO.houseNo} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.alley != null and comMngPopulationVO.alley != &quot;&quot;'>" +
-            "AND cmv.alley LIKE concat(#{comMngPopulationVO.alley},'%') " +
-            " </if> " +
-            "<if test='comMngPopulationVO.sex != null and comMngPopulationVO.sex != &quot;&quot;'>" +
-            "AND cmp.sex = #{comMngPopulationVO.sex} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.ageStartTime != null and comMngPopulationVO.ageStartTime != &quot;&quot;'>" +
-            "AND date_format(cmp.birthday,'%Y-%m-%d') <![CDATA[ <= ]]> #{comMngPopulationVO.ageStartTime} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.ageEndTime != null and comMngPopulationVO.ageEndTime != &quot;&quot;'>" +
-            "AND date_format(cmp.birthday,'%Y-%m-%d') <![CDATA[ >= ]]> #{comMngPopulationVO.ageEndTime} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.nativePlace != null and comMngPopulationVO.nativePlace != &quot;&quot;'>" +
-            "AND cmp.native_place LIKE concat(#{comMngPopulationVO.nativePlace},'%') " +
-            " </if> " +
-            "<if test='comMngPopulationVO.nation != null and comMngPopulationVO.nation != &quot;&quot;'>" +
-            "AND cmp.nation = #{comMngPopulationVO.nation} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.politicalOutlook != null and comMngPopulationVO.politicalOutlook != &quot;&quot;'>" +
-            "AND cmp.political_outlook = #{comMngPopulationVO.politicalOutlook} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.cardNo != null and comMngPopulationVO.cardNo != &quot;&quot;'>" +
-            "AND cmp.card_no = #{comMngPopulationVO.cardNo} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.remark != null and comMngPopulationVO.remark != &quot;&quot;'>" +
-            "AND cmp.remark = #{comMngPopulationVO.remark} " +
-            " </if> " +
-            "<if test='comMngPopulationVO.address != null and comMngPopulationVO.address != &quot;&quot;'>" +
-            "AND cmp.address like concat('%', #{comMngPopulationVO.address}, '%')  " +
-            " </if> " +
-            " </where>" +
-            " order by cmp.create_at desc" +
-            "</script>")
-    IPage<ComMngPopulationVO> pagePopulation(Page page, @Param("comMngPopulationVO") ComMngPopulationDTO comMngPopulationVO);
+    @Select("SELECT cmphu.popul_id,cmphu.relation,cmp.NAME,cmp.phone,cmp.healthy,cmp.card_no,cmp.work_company,cmp.birthday FROM com_mng_population_house_user cmphu "
+        + " LEFT JOIN com_mng_population cmp ON cmphu.popul_id = cmp.id " + " WHERE cmphu.popul_id = #{populId}")
+    List<ComHouseMemberVo> listHouseMermberByPopuId(@Param("populId") Long populId);
 
-    @Select("<script> " +
-            "select cmp.id,cmv.`alley` as areaName,cmp.`name`,cmp.phone,cmp.label as tags,cmp.create_at from com_mng_population as cmp " +
-            "left join com_mng_village as cmv on cmv.village_id = cmp.village_id where cmp.act_id = #{pageInputUserDTO.communityId} and cmp.label is not null " +
-            "<if test='pageInputUserDTO.name != null and pageInputUserDTO.name != &quot;&quot;'>" +
-            " AND cmp.`name` LIKE concat(#{pageInputUserDTO.name},'%') " +
-            " </if> " +
-            "<if test='pageInputUserDTO.areaName != null and pageInputUserDTO.areaName != &quot;&quot;'>" +
-            " AND cmv.`alley` LIKE concat(#{pageInputUserDTO.areaName},'%') " +
-            " </if> " +
-            "<if test='pageInputUserDTO.tags != null and pageInputUserDTO.tags != &quot;&quot;'>" +
-            " AND cmp.label like concat('%',#{pageInputUserDTO.tags},'%') " +
-            " </if> " +
-            " order by cmp.create_at desc " +
-            "</script>")
+    @Select("<script> " + "SELECT " + "cmp.`name`, " + "cmp.id, " + "cmp.street_id, " + "cmp.act_id, "
+        + "cmp.village_id, " + "cmp.sex, " + "cmp.card_no, " + "cmp.road, " + "cmp.door_no, " + "cmp.floor, "
+        + "cmp.unit_no, " + "cmp.house_no, " + "cmp.political_outlook, " + "cmp.work_company, "
+        + "cmp.special_situation, " + "cmp.phone, " + "cmp.remark, " + "cmp.native_place, " + "cmp.nation,  "
+        + "cmpct.label,  " + "cmp.marriage,  " + "cmp.culture_level,  " + "cmp.profession,  " + "cmp.out_or_local,  "
+        + "cmp.census_register,  " + "cmp.healthy,  " + "cmp.birthday,  " + "cmp.update_at,  " + "cmp.address,  "
+        + "cmp.is_rent,cmp.death  " + "FROM  " + "com_mng_population AS cmp "
+        + " LEFT JOIN com_mng_population_community_tags AS cmpct ON cmp.id = cmpct.population_id  " + "<where>"
+        + "<if test='comMngPopulationVO.name != null and comMngPopulationVO.name != &quot;&quot;'>"
+        + "AND cmp.`name` LIKE concat(#{comMngPopulationVO.name},'%') " + " </if> "
+        + "<if test='comMngPopulationVO.label != null and comMngPopulationVO.label != &quot;&quot;'>"
+        + "AND cmpct.label LIKE concat('%',#{comMngPopulationVO.label},'%') " + " </if> "
+        + "<if test='comMngPopulationVO.actId != null'>" + " and cmpct.community_id = ${comMngPopulationVO.actId} "
+        + " </if> " + "<if test='comMngPopulationVO.outOrLocal != null'>"
+        + " and cmp.out_or_local = #{comMngPopulationVO.outOrLocal} " + " </if> "
+        + "<if test='comMngPopulationVO.villageId != null and comMngPopulationVO.villageId != &quot;&quot;'>"
+        + " and cmp.village_id = #{comMngPopulationVO.villageId} " + " </if> "
+        + "<if test='comMngPopulationVO.road != null and comMngPopulationVO.road != &quot;&quot;'>"
+        + "AND cmp.road = #{comMngPopulationVO.road} " + " </if> "
+        + "<if test='comMngPopulationVO.doorNo != null and comMngPopulationVO.doorNo != &quot;&quot;'>"
+        + "AND cmp.door_no = #{comMngPopulationVO.doorNo} " + " </if> "
+        + "<if test='comMngPopulationVO.floor != null and comMngPopulationVO.floor != &quot;&quot;'>"
+        + "AND cmp.floor = #{comMngPopulationVO.floor} " + " </if> "
+        + "<if test='comMngPopulationVO.unitNo != null and comMngPopulationVO.unitNo != &quot;&quot;'>"
+        + "AND cmp.unit_no = #{comMngPopulationVO.unitNo} " + " </if> "
+        + "<if test='comMngPopulationVO.houseNo != null and comMngPopulationVO.houseNo != &quot;&quot;'>"
+        + "AND cmp.house_no = #{comMngPopulationVO.houseNo} " + " </if> "
+        + "<if test='comMngPopulationVO.isDeath != null'>"
+        + "AND cmp.death = #{comMngPopulationVO.isDeath} " + " </if> "
+        + "<if test='comMngPopulationVO.sex != null and comMngPopulationVO.sex != &quot;&quot;'>"
+        + "AND cmp.sex = #{comMngPopulationVO.sex} " + " </if> "
+        + "<if test='comMngPopulationVO.ageStartTime != null and comMngPopulationVO.ageStartTime != &quot;&quot; and comMngPopulationVO.ageEndTime == null'>"
+        + "AND date_format(cmp.birthday,'%Y-%m-%d') <![CDATA[ <= ]]> #{comMngPopulationVO.ageStartTime} " + " </if> "
+        + "<if test='comMngPopulationVO.ageEndTime != null and comMngPopulationVO.ageEndTime != &quot;&quot; and comMngPopulationVO.ageStartTime == null'>"
+        + "AND date_format(cmp.birthday,'%Y-%m-%d') <![CDATA[ >= ]]> #{comMngPopulationVO.ageEndTime} " + " </if> "
+        + "<if test='comMngPopulationVO.ageStartTime != null and comMngPopulationVO.ageEndTime != null and comMngPopulationVO.ageStartTime == comMngPopulationVO.ageEndTime'>"
+        + "AND cmp.birthday BETWEEN #{comMngPopulationVO.ageStartTimeEnd} and #{comMngPopulationVO.ageEndTime}"
+        + " </if> "
+        + "<if test='comMngPopulationVO.ageStartTime != null and comMngPopulationVO.ageEndTime != null and comMngPopulationVO.ageStartTime != comMngPopulationVO.ageEndTime'>"
+        + "AND cmp.birthday BETWEEN #{comMngPopulationVO.ageEndTimeEnd} and #{comMngPopulationVO.ageStartTime}"
+        + " </if> "
+        + "<if test='comMngPopulationVO.searchKey != null and comMngPopulationVO.searchKey != &quot;&quot; '>"
+        + "AND (cmp.name like concat('%',#{comMngPopulationVO.searchKey},'%') or cmp.card_no_str like concat('%',#{comMngPopulationVO.searchKey},'%') or cmp.phone like concat('%',#{comMngPopulationVO.searchKey},'%') "
+        + " </if> "
+        + "<if test='comMngPopulationVO.nativePlace != null and comMngPopulationVO.nativePlace != &quot;&quot;'>"
+        + "AND cmp.native_place LIKE concat(#{comMngPopulationVO.nativePlace},'%') " + " </if> "
+        + "<if test='comMngPopulationVO.nation != null and comMngPopulationVO.nation != &quot;&quot;'>"
+        + "AND cmp.nation = #{comMngPopulationVO.nation} " + " </if> "
+        + "<if test='comMngPopulationVO.politicalOutlook != null and comMngPopulationVO.politicalOutlook != &quot;&quot;'>"
+        + "AND cmp.political_outlook = #{comMngPopulationVO.politicalOutlook} " + " </if> "
+        + "<if test='comMngPopulationVO.cardNo != null and comMngPopulationVO.cardNo != &quot;&quot;'>"
+        + "AND cmp.card_no = #{comMngPopulationVO.cardNo} " + " </if> "
+        + "<if test='comMngPopulationVO.remark != null and comMngPopulationVO.remark != &quot;&quot;'>"
+        + "AND cmp.remark = #{comMngPopulationVO.remark} " + " </if> " + " </where>" + " order by cmp.create_at desc"
+        + "</script>")
+    IPage<ComMngPopulationVO> pagePopulation(Page page,
+        @Param("comMngPopulationVO") ComMngPopulationDTO comMngPopulationVO);
+
+    /**
+     * 导出老人列表
+     * @param comMngPopulationVO
+     * @return
+     */
+    List<ComMngPopulationVO> exportOld(@Param("comMngPopulationVO") ComMngPopulationDTO comMngPopulationVO);
+
+    /**
+     * 分页查询特殊群体列表
+     * @param page  分页参数
+     * @param pageInputUserDTO  请求参数
+     * @return  特殊群体列表
+     */
     IPage<InputUserInfoVO> specialInputUser(Page page, @Param("pageInputUserDTO") PageInputUserDTO pageInputUserDTO);
 
-    @Select("<script> " +
-            "select id,tag_name,community_id,create_at,sys_flag from com_mng_user_tag where community_id = #{comMngUserTagDTO.communityId}" +
-            "<if test='comMngUserTagDTO.tagName != null and comMngUserTagDTO.tagName != &quot;&quot;'>" +
-            " AND tag_name LIKE concat(#{comMngUserTagDTO.tagName},'%') " +
-            " </if> " +
-            " order by create_at desc " +
-            "</script>")
+    /**
+     *
+     * @param pageInputUserDTO
+     * @return
+     */
+    List<InputUserInfoVO> specialInputUserExport(@Param("pageInputUserDTO") PageInputUserDTO pageInputUserDTO);
+
+    @Select("<script> "
+        + "select id,tag_name,community_id,create_at,sys_flag from com_mng_user_tag <where> "
+        + "<if test='comMngUserTagDTO.tagName != null and comMngUserTagDTO.tagName != &quot;&quot;'>"
+        + " AND tag_name LIKE concat(#{comMngUserTagDTO.tagName},'%') " + " </if> " + "</where>" + " order by create_at desc "
+        + "</script>")
     IPage<ComMngTagVO> specialInputUserTags(Page page, @Param("comMngUserTagDTO") PageInputUserDTO comMngUserTagDTO);
 
     @Select("select user_id,card_photo_front,card_photo_back,family_book from sys_user where id_card=#{idCard}")
@@ -258,855 +189,522 @@
     @Select("update sys_user set card_photo_front=#{vo.cardPhotoFront},card_photo_back=#{vo.cardPhotoBack},family_book=#{vo.familyBook} where user_id=#{vo.userId}")
     void updateSysUserElectronicFile(@Param("vo") UserElectronicFileVO vo);
 
-    @Select("<script> " +
-            "select (select province_name from com_mng_struct_area_province where province_adcode = #{provinceCode}) as province," +
-            "(select city_name from com_mng_struct_area_city where city_adcode = #{cityCode}) as city," +
-            "(select district_name from com_mng_struct_area_district where district_adcode = #{districtCode}) as district" +
-            "</script>")
-    AreaAddressVO getAreaAddress(@Param("provinceCode") String provinceCode,@Param("cityCode") String cityCode,@Param("districtCode") String districtCode);
+    @Select("<script> "
+        + "select (select province_name from com_mng_struct_area_province where province_adcode = #{provinceCode}) as province,"
+        + "(select city_name from com_mng_struct_area_city where city_adcode = #{cityCode}) as city,"
+        + "(select district_name from com_mng_struct_area_district where district_adcode = #{districtCode}) as district"
+        + "</script>")
+    AreaAddressVO getAreaAddress(@Param("provinceCode") String provinceCode, @Param("cityCode") String cityCode,
+        @Param("districtCode") String districtCode);
 
-    @Select("select count(id) as populationTotal " +
-            ",(select count(id) from com_mng_population where act_id = #{communityId} and out_or_local = 1) as localTotal " +
-            ",(select count(id) from com_mng_population where act_id = #{communityId} and out_or_local = 2) as outTotal " +
-            ",(select count(id) from com_mng_population where act_id = #{communityId} and label is not null) as specialTotal " +
-            ",(select count(village_id) from com_mng_village where community_id = #{communityId}) as villageTotal " +
-            " from com_mng_population as cmp where act_id = #{communityId}")
+//    @Select("select count(cmpct.id) as populationTotal "
+//        + ",(select count(cmpct.id) from com_mng_population_community_tags cmpct left join com_mng_population cmp on cmpct.population_id = cmp.id where cmpct.community_id = ${communityId} and cmp.out_or_local = 1) as localTotal "
+//        + ",(select count(cmpct.id) from com_mng_population_community_tags cmpct left join com_mng_population cmp on cmpct.population_id = cmp.id where cmpct.community_id = ${communityId} and cmp.out_or_local = 2) as outTotal "
+//        + ",(select count(cmpct.id) from com_mng_population_community_tags cmpct left join com_mng_population cmp on cmpct.population_id = cmp.id where cmpct.community_id = ${communityId} and cmpct.label is not null) as specialTotal "
+//        + ",(select count(DISTINCT `name`) from com_mng_village where community_id = ${communityId}) as villageTotal "
+//        + ",(select count(id) from com_mng_building where act_id = #{communityId}) as buildNum "
+//        + ",(select count(id) from com_mng_population_community_tags where community_id = ${communityId} and label LIKE CONCAT('%','吸毒人员','%')) as drugTotal "
+//        + ",(select count(id) from com_mng_population_community_tags where community_id = ${communityId} and label LIKE CONCAT('%','社区矫正','%')) as correctTotal "
+//        + ",(select count(id) from com_mng_population_community_tags where community_id = ${communityId} and label LIKE CONCAT('%','精神障碍患者','%')) as majorTotal "
+//        + ",(select count(id) from com_mng_population_community_tags where community_id = ${communityId} and label LIKE CONCAT('%','邪教人员','%')) as cultTotal "
+//        + ",(select count(id) from com_mng_population_community_tags where community_id = ${communityId} and label LIKE CONCAT('%','刑释人员','%')) as rehabilitationTotal "
+//        + ",(select count(id) from com_mng_population_community_tags where community_id = ${communityId} and label LIKE CONCAT('%','重点人员','%')) as keyTotal "
+//        + ",(select count(id) from com_mng_population_community_tags where community_id = ${communityId} and label LIKE CONCAT('%','退役军人','%')) as veteransTotal "
+//        + ",(select count(id) from com_mng_population_community_tags where community_id = ${communityId} and label LIKE CONCAT('%','残疾人','%')) as disabilityTotal "
+//        + ",(select count(id) from com_mng_population_community_tags where community_id = ${communityId} and label LIKE CONCAT('%','低保户','%')) as lowSecurityTotal "
+//        + ",(select count(id) from com_mng_population_community_tags where community_id = ${communityId} and label LIKE CONCAT('%','高龄老人','%')) as elderTotal "
+//        + ",(select count(id) from com_mng_population_community_tags where community_id = ${communityId} and label LIKE CONCAT('%','养老金人员','%')) as pensionTotal "
+//        + " from com_mng_population_community_tags as cmpct inner join com_mng_population as cmp on cmp.id = cmpct.population_id where community_id = ${communityId}")
+    /**
+     * 实有人口统计
+     * @param communityId
+     * @return
+     */
     ComMngPopulationTotalVO getPopulationTotalByAdmin(@Param("communityId") Long communityId);
 
     @Select("select count(id) as populationTotal," +
-            "IFNULL((select count(id) from com_mng_population_house where community_id = cmp.act_id),0) as houseTotal, " +
-            "IFNULL((select count(id) from com_mng_real_company where community_id = cmp.act_id),0) as companyTotal, " +
-            "IFNULL((select count(village_id) from com_mng_village where community_id = cmp.act_id),0) as villageTotal " +
-            " from com_mng_population as cmp " +
-            " where act_id = #{communityId}")
+            "IFNULL((select count(id) from com_mng_population_house where community_id = cmpct.community_id),0) as houseTotal, " +
+            "IFNULL((select count(id) from com_mng_real_company where community_id = cmpct.community_id),0) as companyTotal, " +
+            "IFNULL((select count(DISTINCT `name`) from com_mng_village where community_id = cmpct.community_id),0) as villageTotal " +
+            " from com_mng_population_community_tags AS cmpct " +
+            " where cmpct.community_id = ${communityId}")
     IndexBasicsStatisticsVO getScreenIndexByBasics(@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " IFNULL( NULL, 1 ) AS type, " +
-            " count( id ) AS sum  " +
-            "FROM " +
-            " com_mng_population  " +
-            "WHERE " +
-            " sex = 1  " +
-            " AND act_id = #{communityId} UNION ALL " +
-            "SELECT " +
-            " IFNULL( NULL, 2 ) AS type, " +
-            " count( id ) AS sum  " +
-            "FROM " +
-            " com_mng_population  " +
-            "WHERE " +
-            " sex = 2  " +
-            " AND act_id = #{communityId}")
+    @Select("SELECT    cmp.sex as type,    count( cmpct.id ) AS sum,  count( cmpct.id )*100/(select count(*) from com_mng_population_community_tags as cmpct  \n" +
+            "          left join com_mng_population  as cmp on cmpct.population_id = cmp.id   WHERE    cmpct.community_id = ${communityId} ) as percent    FROM \n" +
+            "          com_mng_population_community_tags as cmpct  \n" +
+            "          left join com_mng_population  as cmp on cmpct.population_id = cmp.id   WHERE cmp.sex is not null  and  cmpct.community_id = ${communityId} GROUP BY cmp.sex")
     List<IndexPopulationSexStatisticsVO> getScreenIndexByPopulationSex(@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " e.happen_time as createAt, " +
-            " e.event_des, " +
-            " e.event_deal_status  " +
-            "FROM " +
-            " `event` AS e " +
-            " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id  " +
-            "WHERE " +
-            " egd.grid_community_id = #{communityId}  " +
-            " AND e.event_deal_status IN ( 1, 4 )  " +
-            "ORDER BY " +
-            " e.happen_time DESC  " +
-            " LIMIT 8")
+    @Select("SELECT " + " e.happen_time as createAt, " + " e.event_des, " + " e.event_deal_status  " + "FROM "
+        + " `event` AS e " + " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id  " + "WHERE "
+        + " egd.grid_community_id = ${communityId}  " + " AND e.event_deal_status IN ( 1, 4 )  " + "ORDER BY "
+        + " e.happen_time DESC  " + " LIMIT 8")
     List<IndexEventListStatisticsVO> getScreenIndexByEventList(@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " count( id ) AS microWishTotal, " +
-            " IFNULL(( SELECT count( id ) FROM com_act_easy_photo WHERE status = 4 AND community_id = camw.community_id ),0) AS easyPhotoTotal, " +
-            " IFNULL(( SELECT count( id ) FROM com_act_message WHERE STATUS = 2 AND community_id = camw.community_id ),0) AS replyTotal, " +
-            " IFNULL(( SELECT count( id ) FROM com_act_activity WHERE STATUS = 5 AND community_id = camw.community_id ),0) AS actTotal, " +
-            " IFNULL(( SELECT count( id ) FROM com_pb_activity WHERE STATUS = 5 AND community_id = camw.community_id ),0) AS pbTotal, " +
-            " IFNULL(( SELECT count( id ) FROM com_act_questnaire WHERE community_id = camw.community_id ),0) AS investigationTotal, " +
-            " IFNULL(( SELECT count( id ) FROM com_act_dyn WHERE community_id = camw.community_id AND STATUS = 1 ),0) AS propagandaTotal  " +
-            "FROM " +
-            " com_act_micro_wish AS camw  " +
-            "WHERE " +
-            " camw.STATUS = 6  " +
-            " AND camw.community_id = #{communityId}")
+    @Select("SELECT " + " count( id ) AS microWishTotal, "
+        + " IFNULL(( SELECT count( id ) FROM com_act_easy_photo WHERE status = 4 AND community_id = camw.community_id ),0) AS easyPhotoTotal, "
+        + " IFNULL(( SELECT count( id ) FROM com_act_message WHERE STATUS = 2 AND community_id = camw.community_id ),0) AS replyTotal, "
+        + " IFNULL(( SELECT count( id ) FROM com_act_activity WHERE STATUS = 5 AND community_id = camw.community_id ),0) AS actTotal, "
+        + " IFNULL(( SELECT count( id ) FROM com_pb_activity WHERE STATUS = 5 AND community_id = camw.community_id ),0) AS pbTotal, "
+        + " IFNULL(( SELECT count( id ) FROM com_act_questnaire WHERE community_id = camw.community_id ),0) AS investigationTotal, "
+        + " IFNULL(( SELECT count( id ) FROM com_act_dyn WHERE community_id = camw.community_id AND STATUS = 1 ),0) AS propagandaTotal  "
+        + "FROM " + " com_act_micro_wish AS camw  " + "WHERE " + " camw.STATUS = 6  "
+        + " AND camw.community_id = ${communityId}")
     IndexDynamicStatisticsVO getScreenIndexByDynamic(@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " count( e.id ) AS eventTFTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e1.id )  " +
-            "  FROM " +
-            "   `event` AS e1 " +
-            "   LEFT JOIN event_grid_data AS egd1 ON egd1.id = e1.grid_id  " +
-            "  WHERE " +
-            "   event_category = 1  " +
-            "   AND event_type = 1  " +
-            "   AND event_status = 2  " +
-            "   AND egd1.grid_community_id = #{communityId}  " +
-            "   ), " +
-            "  0  " +
-            " ) AS eventZATotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e2.id )  " +
-            "  FROM " +
-            "   `event` AS e2 " +
-            "   LEFT JOIN event_grid_data AS egd2 ON egd2.id = e2.grid_id  " +
-            "  WHERE " +
-            "   event_category = 1  " +
-            "   AND event_type = 3  " +
-            "   AND event_status = 2  " +
-            "   AND egd2.grid_community_id = #{communityId}  " +
-            "   ), " +
-            "  0  " +
-            " ) AS eventMDTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e3.id )  " +
-            "  FROM " +
-            "   `event` AS e3 " +
-            "   LEFT JOIN event_grid_data AS egd3 ON egd3.id = e3.grid_id  " +
-            "  WHERE " +
-            "   event_category = 1  " +
-            "   AND event_type = 6  " +
-            "   AND event_status = 2  " +
-            "   AND egd3.grid_community_id = #{communityId}  " +
-            "   ), " +
-            "  0  " +
-            " ) AS eventTSTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e4.id )  " +
-            "  FROM " +
-            "   `event` AS e4 " +
-            "   LEFT JOIN event_grid_data AS egd4 ON egd4.id = e4.grid_id  " +
-            "  WHERE " +
-            "   event_category = 1  " +
-            "   AND event_type = 4  " +
-            "   AND event_status = 2  " +
-            "   AND egd4.grid_community_id = #{communityId}  " +
-            "   ), " +
-            "  0  " +
-            " ) AS eventBWDTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e5.id )  " +
-            "  FROM " +
-            "   `event` AS e5 " +
-            "   LEFT JOIN event_grid_data AS egd5 ON egd5.id = e5.grid_id  " +
-            "  WHERE " +
-            "   event_category = 1  " +
-            "   AND event_type = 2  " +
-            "   AND event_status = 2  " +
-            "   AND egd5.grid_community_id = #{communityId}  " +
-            "   ), " +
-            "  0  " +
-            " ) AS eventGGTotal  " +
-            "FROM " +
-            " `event` AS e " +
-            " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id  " +
-            "WHERE " +
-            " e.event_category = 1  " +
-            " AND e.event_type = 5  " +
-            " AND e.event_status = 2  " +
-            " AND egd.grid_community_id = #{communityId}")
+    @Select("SELECT " + " count( e.id ) AS eventTFTotal, " + " IFNULL(( " + "  SELECT " + "   count( e1.id )  "
+        + "  FROM " + "   `event` AS e1 " + "   LEFT JOIN event_grid_data AS egd1 ON egd1.id = e1.grid_id  "
+        + "  WHERE " + "   event_category = 1  " + "   AND event_type = 1  " + "   AND event_status = 2  "
+        + "   AND egd1.grid_community_id = ${communityId}  " + "   ), " + "  0  " + " ) AS eventZATotal, "
+        + " IFNULL(( " + "  SELECT " + "   count( e2.id )  " + "  FROM " + "   `event` AS e2 "
+        + "   LEFT JOIN event_grid_data AS egd2 ON egd2.id = e2.grid_id  " + "  WHERE " + "   event_category = 1  "
+        + "   AND event_type = 3  " + "   AND event_status = 2  " + "   AND egd2.grid_community_id = ${communityId}  "
+        + "   ), " + "  0  " + " ) AS eventMDTotal, " + " IFNULL(( " + "  SELECT " + "   count( e3.id )  " + "  FROM "
+        + "   `event` AS e3 " + "   LEFT JOIN event_grid_data AS egd3 ON egd3.id = e3.grid_id  " + "  WHERE "
+        + "   event_category = 1  " + "   AND event_type = 6  " + "   AND event_status = 2  "
+        + "   AND egd3.grid_community_id = ${communityId}  " + "   ), " + "  0  " + " ) AS eventTSTotal, "
+        + " IFNULL(( " + "  SELECT " + "   count( e4.id )  " + "  FROM " + "   `event` AS e4 "
+        + "   LEFT JOIN event_grid_data AS egd4 ON egd4.id = e4.grid_id  " + "  WHERE " + "   event_category = 2  "
+        + "   AND event_status = 2  " + "   AND egd4.grid_community_id = ${communityId}  "
+        + "   ), " + "  0  " + " ) AS eventBWDTotal, " + " IFNULL(( " + "  SELECT " + "   count( e5.id )  " + "  FROM "
+        + "   `event` AS e5 " + "   LEFT JOIN event_grid_data AS egd5 ON egd5.id = e5.grid_id  " + "  WHERE "
+        + "   event_category = 1  " + "   AND event_type = 2  " + "   AND event_status = 2  "
+        + "   AND egd5.grid_community_id = ${communityId}  " + "   ), " + "  0  " + " ) AS eventGGTotal  " + "FROM "
+        + " `event` AS e " + " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id  " + "WHERE "
+        + " e.event_category = 1  " + " AND e.event_type = 5  " + " AND e.event_status = 2  "
+        + " AND egd.grid_community_id = ${communityId}")
     IndexGridEventStatisticsVO getGridEventStatisticsList(@Param("communityId") Long communityId);
 
-    @Select("select id,grid_name from event_grid_data where grid_community_id = #{communityId}")
+    @Select("select id,grid_name from event_grid_data where grid_community_id = ${communityId}")
     List<EventGridDataVO> getGridDataListByCommunityId(@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " count( e.id ) AS eventTFTotal, " +
-            " IFNULL(( SELECT count( id ) FROM `event` WHERE event_category = 1 AND event_type = 1 AND event_status = 2 AND grid_id = e.grid_id ),0) AS eventZATotal, " +
-            " IFNULL(( SELECT count( id ) FROM `event` WHERE event_category = 1 AND event_type = 3 AND event_status = 2 AND grid_id = e.grid_id) ,0) AS eventMDTotal, " +
-            " IFNULL(( SELECT count( id ) FROM `event` WHERE event_category = 1 AND event_type = 6 AND event_status = 2 AND grid_id = e.grid_id ),0) AS eventTSTotal, " +
-            " IFNULL(( SELECT count( id ) FROM `event` WHERE event_category = 1 AND event_type = 4 AND event_status = 2 AND grid_id = e.grid_id ),0) AS eventBWDTotal, " +
-            " IFNULL(( SELECT count( id ) FROM `event` WHERE event_category = 1 AND event_type = 2 AND event_status = 2 AND grid_id = e.grid_id ),0) AS eventGGTotal  " +
-            "FROM " +
-            " `event` AS e " +
-            "WHERE " +
-            " e.event_category = 1  " +
-            " AND e.event_type = 5  " +
-            " AND e.event_status = 2  " +
-            " AND e.grid_id = #{gridId}")
+    @Select("SELECT " + " count( e.id ) AS eventTFTotal, "
+        + " IFNULL(( SELECT count( id ) FROM `event` WHERE event_category = 1 AND event_type = 1 AND event_status = 2 AND grid_id = e.grid_id ),0) AS eventZATotal, "
+        + " IFNULL(( SELECT count( id ) FROM `event` WHERE event_category = 1 AND event_type = 3 AND event_status = 2 AND grid_id = e.grid_id) ,0) AS eventMDTotal, "
+        + " IFNULL(( SELECT count( id ) FROM `event` WHERE event_category = 1 AND event_type = 6 AND event_status = 2 AND grid_id = e.grid_id ),0) AS eventTSTotal, "
+        + " IFNULL(( SELECT count( id ) FROM `event` WHERE event_category = 1 AND event_type = 4 AND event_status = 2 AND grid_id = e.grid_id ),0) AS eventBWDTotal, "
+        + " IFNULL(( SELECT count( id ) FROM `event` WHERE event_category = 1 AND event_type = 2 AND event_status = 2 AND grid_id = e.grid_id ),0) AS eventGGTotal  "
+        + "FROM " + " `event` AS e " + "WHERE " + " e.event_category = 1  " + " AND e.event_type = 5  "
+        + " AND e.event_status = 2  " + " AND e.grid_id = #{gridId}")
     IndexGridEventStatisticsVO getGridEventByGirdId(@Param("gridId") Long gridId);
 
-    @Select("SELECT " +
-            " tag_name, " +
-            " sys_flag  " +
-            "FROM " +
-            " com_mng_user_tag  " +
-            "WHERE " +
-            " sys_flag = 1  " +
-            " OR community_id = #{communityId}")
+    @Select("SELECT " + " tag_name, " + " sys_flag  " + "FROM " + " com_mng_user_tag  " + "WHERE " + " sys_flag = 1  "
+        + " OR community_id = ${communityId}")
     List<ComMngUserTagVO> getUserTagListByCommunityId(@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " count( id )  " +
-            "FROM " +
-            " com_mng_population  " +
-            "WHERE " +
-            " label like concat('%',#{label},'%')")
-    Integer getSpecialStatisticsByLabel(@Param("label") String label);
+    @Select("SELECT " + " count( id )  " + "FROM " + " com_mng_population_community_tags  " + "WHERE "
+        + " community_id = ${communityId} and label like concat('%',#{label},'%')")
+    Integer getSpecialStatisticsByLabel(@Param("label") String label,@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " count( egd.id ) AS gridTotal, " +
-            " ( SELECT count( user_id ) FROM sys_user WHERE community_id = egd.grid_community_id AND type = 6 ) AS gridMemberTotal, " +
-            " ( " +
-            " SELECT " +
-            "  count( e.id )  " +
-            " FROM " +
-            "  `event` AS e " +
-            "  LEFT JOIN event_grid_data AS egd1 ON e.grid_id = egd1.id  " +
-            " WHERE " +
-            "  egd1.grid_community_id = egd.grid_community_id  " +
-            "  AND event_status = 2  " +
-            " ) AS eventTotal, " +
-            " ( " +
-            " SELECT " +
-            "  count( e1.id )  " +
-            " FROM " +
-            "  `event` AS e1 " +
-            "  LEFT JOIN event_grid_data AS egd2 ON e1.grid_id = egd2.id  " +
-            " WHERE " +
-            "  egd2.grid_community_id = egd.grid_community_id  " +
-            "  AND event_status = 2  " +
-            " AND event_deal_status IN ( 1, 2, 3 )) AS noSolveEventTotal, " +
-            " ( " +
-            " SELECT " +
-            "  count( e1.id )  " +
-            " FROM " +
-            "  `event` AS e1 " +
-            "  LEFT JOIN event_grid_data AS egd2 ON e1.grid_id = egd2.id  " +
-            " WHERE " +
-            "  egd2.grid_community_id = egd.grid_community_id  " +
-            "  AND event_status = 2  " +
-            "  AND event_deal_status = 4  " +
-            " ) AS solveEventTotal  " +
-            "FROM " +
-            " event_grid_data AS egd  " +
-            "WHERE " +
-            " egd.grid_community_id = #{communityId}")
-    EventLeftTopStatisticsVO getEventScreenLeftTop(@Param("communityId") Long communityId);
+    @Select("SELECT " + " count( id )  " + "FROM " + " com_mng_population_community_tags  " + "WHERE "
+            + " community_id = ${communityId} ")
+    Integer getSpecialStatistics(@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " DATE_FORMAT( e.create_at, '%m' ) months  " +
-            "FROM " +
-            " `event` AS e " +
-            " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id  " +
-            "WHERE " +
-            " e.create_at BETWEEN concat( YEAR ( now()), '-01-01 00:00:00' )  " +
-            " AND concat( YEAR ( now()), '-12-31 23:59:59' )  " +
-            " AND egd.grid_community_id = #{communityId}  " +
-            "GROUP BY " +
-            " months  " +
-            "ORDER BY " +
-            " count( e.id ) DESC  " +
-            " LIMIT 3")
+    @Select("<script> " + "SELECT " + " count( egd.id ) AS gridTotal, "
+        + " ( select count(egmr.id) from event_grid_member_relation as egmr"
+        + " left join event_grid_data as egd1 on egd1.id = egmr.grid_id where egd1.grid_community_id = egd.grid_community_id ) AS gridMemberTotal, "
+        + " ( " + " SELECT " + "  count( e.id )  " + " FROM " + "  `event` AS e "
+        + "  LEFT JOIN event_grid_data AS egd1 ON e.grid_id = egd1.id  " + " WHERE "
+        + "  egd1.grid_community_id = egd.grid_community_id  " + "  AND event_status = 2  "
+        + "<if test='screenEventDTO.startTime != null and screenEventDTO.startTime != &quot;&quot;'>"
+        + " AND e.create_at <![CDATA[>=]]> #{screenEventDTO.startTime} " + " </if> "
+        + "<if test='screenEventDTO.endTime != null and screenEventDTO.endTime != &quot;&quot;'>"
+        + " AND e.create_at <![CDATA[<=]]> #{screenEventDTO.endTime} " + " </if> " + " ) AS eventTotal, " + " ( "
+        + " SELECT " + "  count( e1.id )  " + " FROM " + "  `event` AS e1 "
+        + "  LEFT JOIN event_grid_data AS egd2 ON e1.grid_id = egd2.id  " + " WHERE "
+        + "  egd2.grid_community_id = egd.grid_community_id  " + "  AND event_status = 2  "
+        + "<if test='screenEventDTO.startTime != null and screenEventDTO.startTime != &quot;&quot;'>"
+        + " AND e1.create_at <![CDATA[>=]]> #{screenEventDTO.startTime} " + " </if> "
+        + "<if test='screenEventDTO.endTime != null and screenEventDTO.endTime != &quot;&quot;'>"
+        + " AND e1.create_at <![CDATA[<=]]> #{screenEventDTO.endTime} " + " </if> "
+        + " AND event_deal_status IN ( 1, 2, 3 )) AS noSolveEventTotal, " + " ( " + " SELECT " + "  count( e1.id )  "
+        + " FROM " + "  `event` AS e1 " + "  LEFT JOIN event_grid_data AS egd2 ON e1.grid_id = egd2.id  " + " WHERE "
+        + "  egd2.grid_community_id = egd.grid_community_id  " + "  AND event_status = 2  "
+        + "  AND event_deal_status = 4  "
+        + "<if test='screenEventDTO.startTime != null and screenEventDTO.startTime != &quot;&quot;'>"
+        + " AND e1.create_at <![CDATA[>=]]> #{screenEventDTO.startTime} " + " </if> "
+        + "<if test='screenEventDTO.endTime != null and screenEventDTO.endTime != &quot;&quot;'>"
+        + " AND e1.create_at <![CDATA[<=]]> #{screenEventDTO.endTime} " + " </if> " + " ) AS solveEventTotal  "
+        + "FROM " + " event_grid_data AS egd  " + "WHERE " + " egd.grid_community_id = ${screenEventDTO.communityId} "
+        + " </script>")
+    EventLeftTopStatisticsVO getEventScreenLeftTop(@Param("screenEventDTO") BigScreenEventDTO screenEventDTO);
+
+    @Select("SELECT " + " DATE_FORMAT( e.create_at, '%m' ) months  " + "FROM " + " `event` AS e "
+        + " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id  " + "WHERE "
+        + " e.create_at BETWEEN concat( YEAR ( now()), '-01-01 00:00:00' )  "
+        + " AND concat( YEAR ( now()), '-12-31 23:59:59' )  " + " AND egd.grid_community_id = ${communityId}  "
+        + "GROUP BY " + " months  " + "ORDER BY " + " count( e.id ) DESC  " + " LIMIT 3")
     List<Integer> getFrequentlyEventMonth(@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " count( e.id ) AS eventZATotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e1.id )  " +
-            "  FROM " +
-            "   `event` AS e1 " +
-            "   LEFT JOIN event_grid_data AS egd1 ON egd1.id = e1.grid_id  " +
-            "  WHERE " +
-            "   egd1.grid_community_id = #{communityId}  " +
-            "   AND event_category = 1  " +
-            "   AND event_type = 1  " +
-            "   AND event_deal_status = 4  " +
-            "   ), " +
-            "  0  " +
-            " ) AS yesEventZATotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e2.id )  " +
-            "  FROM " +
-            "   `event` AS e2 " +
-            "   LEFT JOIN event_grid_data AS egd2 ON egd2.id = e2.grid_id  " +
-            "  WHERE " +
-            "   egd2.grid_community_id = #{communityId}  " +
-            "   AND event_category = 1  " +
-            "   AND event_type = 5  " +
-            "   AND event_status = 2  " +
-            "   ), " +
-            "  0  " +
-            " ) AS eventTFTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e3.id )  " +
-            "  FROM " +
-            "   `event` AS e3 " +
-            "   LEFT JOIN event_grid_data AS egd3 ON egd3.id = e3.grid_id  " +
-            "  WHERE " +
-            "   egd3.grid_community_id = #{communityId}  " +
-            "   AND event_category = 1  " +
-            "   AND event_type = 5  " +
-            "   AND event_deal_status = 4  " +
-            "   ), " +
-            "  0  " +
-            " ) AS yesEventTFTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e4.id )  " +
-            "  FROM " +
-            "   `event` AS e4 " +
-            "   LEFT JOIN event_grid_data AS egd4 ON egd4.id = e4.grid_id  " +
-            "  WHERE " +
-            "   egd4.grid_community_id = #{communityId}  " +
-            "   AND event_category = 1  " +
-            "   AND event_type = 6  " +
-            "   AND event_status = 2  " +
-            "   ), " +
-            "  0  " +
-            " ) AS eventTSTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e5.id )  " +
-            "  FROM " +
-            "   `event` AS e5 " +
-            "   LEFT JOIN event_grid_data AS egd5 ON egd5.id = e5.grid_id  " +
-            "  WHERE " +
-            "   egd5.grid_community_id = #{communityId}  " +
-            "   AND event_category = 1  " +
-            "   AND event_type = 6  " +
-            "   AND event_deal_status = 4  " +
-            "   ), " +
-            "  0  " +
-            " ) AS yesEventTSTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e6.id )  " +
-            "  FROM " +
-            "   `event` AS e6 " +
-            "   LEFT JOIN event_grid_data AS egd6 ON egd6.id = e6.grid_id  " +
-            "  WHERE " +
-            "   egd6.grid_community_id = #{communityId}  " +
-            "   AND event_category = 1  " +
-            "   AND event_type = 3  " +
-            "   AND event_status = 2  " +
-            "   ), " +
-            "  0  " +
-            " ) AS eventMDTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e7.id )  " +
-            "  FROM " +
-            "   `event` AS e7 " +
-            "   LEFT JOIN event_grid_data AS egd7 ON egd7.id = e7.grid_id  " +
-            "  WHERE " +
-            "   egd7.grid_community_id = #{communityId}  " +
-            "   AND event_category = 1  " +
-            "   AND event_type = 3  " +
-            "   AND event_deal_status = 4  " +
-            "   ), " +
-            "  0  " +
-            " ) AS yesEventMDTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e8.id )  " +
-            "  FROM " +
-            "   `event` AS e8 " +
-            "   LEFT JOIN event_grid_data AS egd8 ON egd8.id = e8.grid_id  " +
-            "  WHERE " +
-            "   egd8.grid_community_id = #{communityId}  " +
-            "   AND event_category = 1  " +
-            "   AND event_type = 4  " +
-            "   AND event_status = 2  " +
-            "   ), " +
-            "  0  " +
-            " ) AS eventBWDTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e9.id )  " +
-            "  FROM " +
-            "   `event` AS e9 " +
-            "   LEFT JOIN event_grid_data AS egd9 ON egd9.id = e9.grid_id  " +
-            "  WHERE " +
-            "   egd9.grid_community_id = #{communityId}  " +
-            "   AND event_category = 1  " +
-            "   AND event_type = 4  " +
-            "   AND event_deal_status = 4  " +
-            "   ), " +
-            "  0  " +
-            " ) AS yesEventBWDTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e10.id )  " +
-            "  FROM " +
-            "   `event` AS e10 " +
-            "   LEFT JOIN event_grid_data AS egd10 ON egd10.id = e10.grid_id  " +
-            "  WHERE " +
-            "   egd10.grid_community_id = #{communityId}  " +
-            "   AND event_category = 1  " +
-            "   AND event_type = 2  " +
-            "   AND event_status = 2  " +
-            "   ), " +
-            "  0  " +
-            " ) AS eventGGTotal, " +
-            " IFNULL(( " +
-            "  SELECT " +
-            "   count( e11.id )  " +
-            "  FROM " +
-            "   `event` AS e11 " +
-            "   LEFT JOIN event_grid_data AS egd11 ON egd11.id = e11.grid_id  " +
-            "  WHERE " +
-            "   egd11.grid_community_id = #{communityId}  " +
-            "   AND event_category = 1  " +
-            "   AND event_type = 2  " +
-            "   AND event_deal_status = 4  " +
-            "   ), " +
-            "  0  " +
-            " ) AS yesEventGGTotal, " +
-            " IFNULL(( SELECT count( id ) FROM com_act_easy_photo WHERE del_tag = 0 AND handle_status IS NOT NULL AND community_id = #{communityId} ), 0 ) AS eventSSPTotal, " +
-            " IFNULL(( SELECT count( id ) FROM com_act_easy_photo WHERE del_tag = 0 AND handle_status = 2 AND community_id = #{communityId} ), 0 ) AS yesEventSSPTotal  " +
-            "FROM " +
-            " `event` AS e " +
-            " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id  " +
-            "WHERE " +
-            " egd.grid_community_id = #{communityId}  " +
-            " AND event_category = 1  " +
-            " AND event_type = 1  " +
-            " AND event_status = 2")
-    EventLeftDownStatisticsVO getEventScreenLeftDown(@Param("communityId") Long communityId);
+    /**
+     * 综治事件大屏统计数据
+     * @param screenEventDTO    请求参数
+     * @return 大屏统计数据
+     */
+    EventLeftDownStatisticsVO getEventScreenLeftDown(@Param("screenEventDTO") BigScreenEventDTO screenEventDTO);
 
-    @Select("SELECT " +
-            " su.nick_name AS userName, " +
-            " su.image_url AS imageUrl, " +
-            " e.happen_time as createAt, " +
-            " e.event_des, " +
-            " e.danger_level, " +
-            " e.urgent, " +
-            " e.major, " +
-            " e.happen_address, " +
-            " e.happent_lat_lng, " +
-            " e.event_type, " +
-            " e.id, " +
-            " e.event_deal_status  " +
-            "FROM " +
-            " `event` AS e " +
-            " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id " +
-            " LEFT JOIN sys_user AS su ON su.user_id = e.grid_member_id  " +
-            "WHERE " +
-            " egd.grid_community_id = #{communityId}  " +
-            " AND e.event_status = 2  " +
-            " AND e.event_deal_status = 1  " +
-            " AND e.event_category = 1  " +
-            "ORDER BY " +
-            " e.happen_time DESC  " +
-            " LIMIT 1")
+    @Select("SELECT " + " su.nick_name AS userName, " + " su.image_url AS imageUrl, " + " e.happen_time as createAt, "
+        + " e.event_des, " + " e.danger_level, " + " e.urgent, " + " e.major, " + " e.happen_address, "
+        + " e.happent_lat_lng, " + " e.event_type, " + " e.id, " + " e.event_deal_status  " + "FROM " + " `event` AS e "
+        + " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id "
+        + " LEFT JOIN sys_user AS su ON su.user_id = e.grid_member_id  " + "WHERE "
+        + " egd.grid_community_id = ${communityId}  " + " AND e.event_status = 2  " + " AND e.event_deal_status = 1  "
+        + " AND e.event_category = 1  " + "ORDER BY " + " e.happen_time DESC  " + " LIMIT 1")
     EventNewStatisticsVO getEventScreenRightTop(@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " grid_name, " +
-            " `data`, " +
-            " line_color, " +
-            " line_broadband, " +
-            " id, " +
-            " fill_color  " +
-            "FROM " +
-            " event_grid_data AS egd  " +
-            "WHERE " +
-            " egd.grid_community_id = #{communityId}")
+    @Select("SELECT " + " grid_name, " + " `data`, " + " line_color, " + " line_broadband, " + " id, " + " fill_color  "
+        + "FROM " + " event_grid_data AS egd  " + "WHERE " + " egd.grid_community_id = ${communityId}")
     List<EventGridStatisticsVO> getEventScreenGridData(@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " event_type AS type, " +
-            " e.id AS eventId, " +
-            " happent_lat_lng AS latLng  " +
-            "FROM " +
-            " `event` AS e " +
-            " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id  " +
-            "WHERE " +
-            " e.event_category = 1  " +
-            " AND e.event_type IN ( 1, 2, 3, 4, 5, 6 )  " +
-            " AND e.event_status = 2  " +
-            " AND egd.grid_community_id = #{communityId}  " +
-            " AND e.create_at >= DATE_SUB(CURDATE(),INTERVAL 30 DAY) UNION ALL " +
-            "SELECT " +
-            " IFNULL( NULL, 7 ) AS type, " +
-            " id AS eventId, " +
-            " lng_lat AS latLng  " +
-            "FROM " +
-            " com_act_easy_photo  " +
-            "WHERE " +
-            " community_id = #{communityId}  " +
-            " AND del_tag = 0  " +
-            " AND lng_lat IS NOT NULL  " +
-            " AND create_at >= DATE_SUB(CURDATE(),INTERVAL 30 DAY)")
-    List<EventGridIncidentStatisticsVO> getEventScreenEventList(@Param("communityId") Long communityId);
+    @Select("<script> " + "(SELECT " + " event_type AS type, " + " e.id AS eventId, " + " happent_lat_lng AS latLng,e.create_at as createAt  "
+        + "FROM " + " `event` AS e " + " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id  " + "WHERE "
+        + " e.event_category = 1  " + " AND e.event_type IN ( 1, 2, 3, 4, 5, 6 )  " + " AND e.event_status = 2  "
+        + " AND egd.grid_community_id = ${screenEventDTO.communityId}  "
+        + "<if test='screenEventDTO.startTime != null and screenEventDTO.startTime != &quot;&quot;'>"
+        + " AND e.create_at <![CDATA[>=]]> #{screenEventDTO.startTime} " + " </if> "
+        + "<if test='screenEventDTO.endTime != null and screenEventDTO.endTime != &quot;&quot;'>"
+        + " AND e.create_at <![CDATA[<=]]> #{screenEventDTO.endTime} " + " </if> "
+        + "<if test='screenEventDTO.eventProcessStatus != null'>"
+        + " AND e.event_process_status = #{screenEventDTO.eventProcessStatus} " + " </if> "
+        + "<if test='screenEventDTO.redCard != null'>" + " AND e.red_card = #{screenEventDTO.redCard} " + " </if> "
+        + "<if test='screenEventDTO.yellowCard != null'>" + " AND e.yellow_card = #{screenEventDTO.yellowCard} "
+        + " </if> )" + "UNION ALL (SELECT " + " IFNULL( NULL, 7 ) AS type, " + " id AS eventId, " + " lng_lat AS latLng,create_at as createAt  "
+        + "FROM " + " com_act_easy_photo  " + "WHERE " + " community_id = ${screenEventDTO.communityId}  "
+        + "<if test='screenEventDTO.startTime != null and screenEventDTO.startTime != &quot;&quot;'>"
+        + " AND create_at <![CDATA[>=]]> #{screenEventDTO.startTime} " + " </if> "
+        + "<if test='screenEventDTO.endTime != null and screenEventDTO.endTime != &quot;&quot;'>"
+        + " AND create_at <![CDATA[<=]]> #{screenEventDTO.endTime} " + " </if> "
+        + "<if test='screenEventDTO.eventProcessStatus != null'>"
+        + " AND handle_status = #{screenEventDTO.eventProcessStatus} " + " </if> )" + "order by createAt desc </script>")
+    List<EventGridIncidentStatisticsVO>
+        getEventScreenEventList(@Param("screenEventDTO") BigScreenEventDTO screenEventDTO);
 
-    @Select("SELECT " +
-            " count( id ) AS specialTotal, " +
-            " ( SELECT count( id ) FROM com_mng_population WHERE label IS NOT NULL AND act_id = #{communityId} AND create_at < #{lastMonth} ) AS toMonthSpecialTotal  " +
-            "FROM " +
-            " com_mng_population AS cmp  " +
-            "WHERE " +
-            " label IS NOT NULL  " +
-            " AND act_id = #{communityId}")
-    CivilPopulationStatisticsVO getCivilScreenPopulation(@Param("communityId") Long communityId,@Param("lastMonth") Date lastMonth);
+    @Select("SELECT " + " count( id ) AS specialTotal, "
+        + " ( SELECT count( id ) FROM com_mng_population_community_tags WHERE label IS NOT NULL AND community_id = ${communityId} AND create_at < #{lastMonth} ) AS toMonthSpecialTotal  "
+        + "FROM " + " com_mng_population_community_tags AS cmpct  " + "WHERE " + " label IS NOT NULL  "
+        + " AND community_id = ${communityId}")
+    CivilPopulationStatisticsVO getCivilScreenPopulation(@Param("communityId") Long communityId,
+        @Param("lastMonth") Date lastMonth);
 
-    @Select("SELECT `NAME`, " +
-            " user_sum, " +
-            " lng, " +
-            " lat, " +
-            " village_images, " +
-            " village_id  " +
-            "FROM " +
-            " com_mng_village AS cmv  " +
-            "WHERE " +
-            " community_id = #{communityId}")
+    @Select("SELECT `NAME`, " + "user_sum, " + " lng, " + " lat, " + " village_images, " + " village_id  " + "FROM "
+        + " com_mng_village AS cmv  " + "WHERE " + " community_id = ${communityId}")
     List<CivilVillageStatisticsVO> getCivilScreenVillageList(@Param("communityId") Long communityId);
 
-    @Select("SELECT " +
-            " count( id ) AS peopleNum, " +
-            " ( SELECT count( id ) FROM com_mng_population_house AS cmph WHERE village_id = #{villageId} ) AS houseNum, " +
-            " ( SELECT count( id ) FROM com_mng_population WHERE village_id = #{villageId} AND out_or_local = 1 ) AS registerNum, " +
-            " ( SELECT count( id ) FROM com_mng_population WHERE village_id = #{villageId} AND out_or_local = 2 ) AS flowNum  " +
-            "FROM " +
-            " com_mng_population AS cmp  " +
-            "WHERE " +
-            " village_id = #{villageId}")
+    @Select("SELECT " + " count( id ) AS peopleNum, "
+        + " ( SELECT count( id ) FROM com_mng_population_house AS cmph WHERE village_id = #{villageId} ) AS houseNum, "
+        + " ( SELECT count( id ) FROM com_mng_population WHERE village_id = #{villageId} AND out_or_local = 1 ) AS registerNum, "
+        + " ( SELECT count( id ) FROM com_mng_population WHERE village_id = #{villageId} AND out_or_local = 2 ) AS flowNum  "
+        + "FROM " + " com_mng_population AS cmp  " + "WHERE " + " village_id = #{villageId}")
     CivilVillageStatisticsVO getCivilScreenVillageStatistics(@Param("villageId") Long villageId);
 
-
-    @Select("SELECT COUNT(id) AS man,(SELECT COUNT(id) FROM com_mng_population WHERE sex = 2 AND act_id = #{communityId}) AS woman FROM com_mng_population WHERE sex = 1 AND act_id = #{communityId}")
+    @Select("SELECT COUNT(cmpct.id) AS man,(SELECT COUNT(cmpct.id) FROM com_mng_population_community_tags as cmpct left join com_mng_population as cmp on cmpct.population_id = cmp.id WHERE cmp.sex = 2 AND cmpct.community_id = ${communityId}) AS woman "
+        + "FROM com_mng_population_community_tags as cmpct left join com_mng_population as cmp on cmpct.population_id = cmp.id WHERE cmp.sex = 1 AND cmpct.community_id = ${communityId}")
     Map<String, Long> countBySex(@Param("communityId") Long communityId);
 
-    @Select(
-            "SELECT " +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) as aa where aa.age<= 16) as age16," +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) AS aa WHERE aa.age > 16 and aa.age<= 25) AS age25," +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) AS aa WHERE aa.age > 25 and aa.age<= 35) AS age35," +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) AS aa WHERE aa.age > 35 and aa.age<= 45) AS age45," +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) AS aa WHERE aa.age > 45 and aa.age<= 55) AS age55," +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) AS aa WHERE aa.age > 55) AS age55over")
-    Map<String, Long> countByAge(@Param("communityId")Long communityId);
+    @Select("SELECT " + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id  WHERE cmpct.community_id = ${communityId}) as aa where aa.age<= 16) as age16,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id  WHERE cmpct.community_id = ${communityId}) AS aa WHERE aa.age > 16 and aa.age<= 25) AS age25,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id  WHERE cmpct.community_id = ${communityId}) AS aa WHERE aa.age > 25 and aa.age<= 35) AS age35,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id  WHERE cmpct.community_id = ${communityId}) AS aa WHERE aa.age > 35 and aa.age<= 45) AS age45,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id  WHERE cmpct.community_id = ${communityId}) AS aa WHERE aa.age > 45 and aa.age<= 55) AS age55,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id  WHERE cmpct.community_id = ${communityId}) AS aa WHERE aa.age > 55) AS age55over")
+    Map<String, Long> countByAge(@Param("communityId") Long communityId);
 
-    @Select("SELECT COUNT(id)AS xx," +
-            "(SELECT COUNT(id) FROM com_mng_population WHERE culture_level = 2 AND act_id = #{communityId}) as cz," +
-            "(SELECT COUNT(id) FROM com_mng_population WHERE culture_level = 3 AND act_id = #{communityId}) as gz," +
-            "(SELECT COUNT(id) FROM com_mng_population WHERE culture_level = 4 AND act_id = #{communityId}) as zz," +
-            "(SELECT COUNT(id) FROM com_mng_population WHERE culture_level = 5 AND act_id = #{communityId}) as dz," +
-            "(SELECT COUNT(id) FROM com_mng_population WHERE culture_level = 6 AND act_id = #{communityId}) as bk," +
-            "(SELECT COUNT(id) FROM com_mng_population WHERE culture_level = 7 AND act_id = #{communityId}) as ss," +
-            "(SELECT COUNT(id) FROM com_mng_population WHERE culture_level = 8 AND act_id = #{communityId}) as bs," +
-            "(SELECT COUNT(id) FROM com_mng_population WHERE culture_level = 9 AND act_id = #{communityId}) as qt" +
-            " FROM com_mng_population WHERE culture_level = 1 AND act_id = #{communityId}")
-    Map<String, Long> countByCulture(@Param("communityId")Long communityId);
+    @Select("SELECT COUNT(cmp.id)AS xx,"
+        + "(SELECT COUNT(cmp.id) FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id WHERE culture_level = 2 AND cmpct.community_id = ${communityId}) as cz,"
+        + "(SELECT COUNT(cmp.id) FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id WHERE culture_level = 3 AND cmpct.community_id = ${communityId}) as gz,"
+        + "(SELECT COUNT(cmp.id) FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id WHERE culture_level = 4 AND cmpct.community_id = ${communityId}) as zz,"
+        + "(SELECT COUNT(cmp.id) FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id WHERE culture_level = 5 AND cmpct.community_id = ${communityId}) as dz,"
+        + "(SELECT COUNT(cmp.id) FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id WHERE culture_level = 6 AND cmpct.community_id = ${communityId}) as bk,"
+        + "(SELECT COUNT(cmp.id) FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id WHERE culture_level = 7 AND cmpct.community_id = ${communityId}) as ss,"
+        + "(SELECT COUNT(cmp.id) FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id WHERE culture_level = 8 AND cmpct.community_id = ${communityId}) as bs,"
+        + "(SELECT COUNT(cmp.id) FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id WHERE culture_level = 9 AND cmpct.community_id = ${communityId}) as qt"
+        + " FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id WHERE culture_level = 1 AND cmpct.community_id = ${communityId}")
+    Map<String, Long> countByCulture(@Param("communityId") Long communityId);
 
-    @Select("select count(user_id) from sys_user where community_id = #{communityId} and type = 1")
-    Long countUsedCommunityPopulation(@Param("communityId")Long communityId);
+    @Select("select count(user_id) from sys_user where community_id = ${communityId} and type = 1")
+    Long countUsedCommunityPopulation(@Param("communityId") Long communityId);
 
-    @Select(
-            "SELECT " +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) as aa where aa.age<= 16) as age16," +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) AS aa WHERE aa.age > 16 and aa.age<= 27) AS age27," +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) AS aa WHERE aa.age > 27 and aa.age<= 35) AS age35," +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) AS aa WHERE aa.age > 35 and aa.age<= 45) AS age45," +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) AS aa WHERE aa.age > 45 and aa.age<= 55) AS age55," +
-                    "(SELECT COUNT(aa.age) FROM " +
-                    "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, birthday, CURDATE()) ) AS age FROM com_mng_population WHERE act_id = #{communityId}) AS aa WHERE aa.age > 55) AS age55over")
-    Map<String, Long> indexCountByAge(@Param("communityId")Long communityId);
+    @Select("SELECT " + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population as cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id WHERE cmpct.community_id = ${communityId}) as aa where aa.age<= 18) as age16,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population_community_tags as capct left join com_mng_population as cmp on cmp.id = capct.population_id and capct.community_id =  ${communityId}) AS aa WHERE aa.age > 19 and aa.age<= 30) AS age27,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population_community_tags as capct left join com_mng_population as cmp on cmp.id = capct.population_id and capct.community_id = ${communityId}) AS aa WHERE aa.age > 31 and aa.age<= 40) AS age35,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population_community_tags as capct left join com_mng_population as cmp on cmp.id = capct.population_id and capct.community_id = ${communityId}) AS aa WHERE aa.age > 41 and aa.age<= 50) AS age45,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population_community_tags as capct left join com_mng_population as cmp on cmp.id = capct.population_id and capct.community_id = ${communityId}) AS aa WHERE aa.age > 51 and aa.age<= 59) AS age55,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population_community_tags as capct left join com_mng_population as cmp on cmp.id = capct.population_id and capct.community_id = ${communityId}) AS aa WHERE aa.age >= 60 and aa.age<= 79) AS age65,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population_community_tags as capct left join com_mng_population as cmp on cmp.id = capct.population_id and capct.community_id = ${communityId}) AS aa WHERE aa.age >= 80 and aa.age<= 89) AS age75,"
+        + "(SELECT COUNT(aa.age) FROM "
+        + "(SELECT (SELECT  TIMESTAMPDIFF(YEAR, cmp.birthday, CURDATE()) ) AS age FROM com_mng_population_community_tags as capct left join com_mng_population as cmp on cmp.id = capct.population_id and capct.community_id = ${communityId}) AS aa WHERE aa.age > 89) AS age55over")
+    Map<String, Long> indexCountByAge(@Param("communityId") Long communityId);
 
+    @Select("SELECT " + " id, " + " su.nick_name AS userName, " + " su.image_url, " + " caep.create_at, "
+        + " caep.detail AS eventDes, " + " caep.happen_addr AS happenAddress, " + " caep.lng_lat AS happentLatLng, "
+        + " caep.photo_path_list, " + " IFNULL( NULL, 7 ) AS eventType, " + " caep.status AS eventDealStatus  "
+        + "FROM " + " com_act_easy_photo AS caep " + " LEFT JOIN sys_user AS su ON su.user_id = caep.sponsor_id  "
+        + "WHERE " + " id = #{eventId}")
+    EventNewStatisticsVO getEventScreenSSPDateil(@Param("eventId") Long eventId);
 
-    @Select("SELECT " +
-            " id, " +
-            " su.nick_name AS userName, " +
-            " su.image_url, " +
-            " caep.create_at, " +
-            " caep.detail AS eventDes, " +
-            " caep.happen_addr AS happenAddress, " +
-            " caep.lng_lat AS happentLatLng, " +
-            " caep.photo_path_list, " +
-            " IFNULL( NULL, 7 ) AS eventType, " +
-            " caep.handle_status AS eventDealStatus  " +
-            "FROM " +
-            " com_act_easy_photo AS caep " +
-            " LEFT JOIN sys_user AS su ON su.user_id = caep.sponsor_id  " +
-            "WHERE " +
-            " id = #{eventId}")
-    EventNewStatisticsVO getEventScreenSSPDateil(@Param("eventId")Long eventId);
-
-    @Select("SELECT " +
-            " su.nick_name AS userName, " +
-            " su.image_url AS imageUrl, " +
-            " e.create_at as createAt, " +
-            " e.event_des, " +
-            " e.event_clazz, " +
-            " e.danger_level, " +
-            " e.urgent, " +
-            " e.major, " +
-            " e.happen_address, " +
-            " e.happent_lat_lng, " +
-            " e.event_type, " +
-            " e.event_category, " +
-            " e.id, " +
-            " egd.grid_name, " +
-            " e.event_deal_status  " +
-            "FROM " +
-            " `event` AS e " +
-            " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id " +
-            " LEFT JOIN sys_user AS su ON su.user_id = e.grid_member_id  " +
-            "WHERE " +
-            " e.id = #{eventId}")
+    @Select("SELECT " + " su.nick_name AS userName, " + " su.image_url AS imageUrl, " + " e.create_at as createAt, "
+        + " e.event_des, " + " e.event_clazz, " + " e.danger_level, " + " e.urgent, " + " e.major,e.process_desc, "
+        + " e.happen_address, " + " e.happent_lat_lng, " + " e.event_type, " + " e.event_category, " + " e.id, "
+        + " egd.grid_name, " + " e.event_deal_status  " + "FROM " + " `event` AS e "
+        + " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id "
+        + " LEFT JOIN sys_user AS su ON su.user_id = e.grid_member_id  " + "WHERE " + " e.id = #{eventId}")
     EventNewStatisticsVO getEventScreenEventDetail(@Param("eventId") Long eventId);
 
     @Select("select process_date,process_result,process_type,from_type,from_id,from_name,event_id from event_transfer_record where event_id = #{eventId}")
     List<EventTransferRecordVO> getEventScreenEventTransList(@Param("eventId") Long eventId);
 
-    @Select("SELECT " +
-            " cs.address AS streetName, " +
-            " ca.`name` AS communityName, " +
-            " egd.grid_name  " +
-            "FROM " +
-            " `event` AS e " +
-            " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id " +
-            " LEFT JOIN com_act AS ca ON egd.grid_community_id = ca.community_id " +
-            " LEFT JOIN com_street AS cs ON cs.street_id = ca.street_id  " +
-            "WHERE " +
-            " e.id = #{eventId}")
+    @Select("SELECT " + " cs.address AS streetName, " + " ca.`name` AS communityName, " + " egd.grid_name  " + "FROM "
+        + " `event` AS e " + " LEFT JOIN event_grid_data AS egd ON egd.id = e.grid_id "
+        + " LEFT JOIN com_act AS ca ON egd.grid_community_id = ca.community_id "
+        + " LEFT JOIN com_street AS cs ON cs.street_id = ca.street_id  " + "WHERE " + " e.id = #{eventId}")
     EventTransferRecordDetailVO getEventScreenEventTransDetail(@Param("eventId") Long eventId);
 
-    @Select("select ca.`name` AS communityName,cs.address AS streetName from com_act as ca LEFT JOIN com_street AS cs ON cs.street_id = ca.street_id where ca.community_id = #{communityId}")
+    @Select("select ca.`name` AS communityName,cs.address AS streetName from com_act as ca LEFT JOIN com_street AS cs ON cs.street_id = ca.street_id where ca.community_id = ${communityId}")
     EventTransferRecordDetailVO getEventScreenEventTransDetailByCommunityId(@Param("communityId") Long communityId);
 
-    @Select("select count(id) from com_elders_auth_elderly WHERE community_id = #{communityId}")
+    @Select("select count(id) from com_elders_auth_elderly WHERE community_id = ${communityId}")
     Integer getStatisticsCount(@Param("communityId") Long communityId);
 
-    @Select("<script> " +
-            "select cmp.id,cmp.`name`,cmp.phone,cmp.card_no,cmp.label,cmp.address,cmp.nation,cmp.political_outlook,cmv.lng,cmv.lat" +
-            ",cmp.sex from com_mng_population as cmp left join com_mng_village as cmv on cmv.village_id = cmp.village_id " +
-            " where cmp.act_id = #{populationListDTO.communityId}" +
-            "<if test='populationListDTO.keyWord != null and populationListDTO.keyWord != &quot;&quot;'>" +
-            "AND (cmp.`name` like concat (#{populationListDTO.keyWord},'%') or cmp.card_no_str like concat (#{populationListDTO.keyWord},'%'))  " +
-            " </if> " +
-            "<if test='populationListDTO.label != null and populationListDTO.label != &quot;&quot;'>" +
-            "AND cmp.label like concat ('%',#{populationListDTO.label},'%') " +
-            " </if> " +
-            " </script>")
-    IPage<PopulationListVO> pagePopulationListApp(Page page, @Param("populationListDTO") PagePopulationListDTO populationListDTO);
+    IPage<PopulationListVO> pagePopulationListApp(Page page,
+        @Param("populationListDTO") PagePopulationListDTO populationListDTO);
 
-    @Select("SELECT " +
-            " cmp.id, " +
-            " cmp.`name`, " +
-            " cmp.phone, " +
-            " cmp.card_no, " +
-            " cmp.label, " +
-            " cmp.address, " +
-            " cmp.nation, " +
-            " cmp.political_outlook, " +
-            " cmp.sex, " +
-            " cmp.birthday, " +
-            " cmp.native_place, " +
-            " cmp.healthy, " +
-            " cmp.is_rent, " +
-            " cmv.alley AS road, " +
-            " cmv.house_num AS doorNo, " +
-            " cmp.floor, " +
-            " cmp.unit_no, " +
-            " cmp.house_no, " +
-            " cmp.work_company, " +
-            " cmp.census_register, " +
-            " cmp.out_or_local, " +
-            " cmp.remark, " +
-            " cmp.marriage " +
-            "FROM " +
-            " com_mng_population AS cmp " +
-            " LEFT JOIN com_mng_village AS cmv ON cmv.village_id = cmp.village_id  " +
-            "WHERE " +
-            " id = #{populationId}")
+    /**
+     * 根据人口id查询人口详情
+     * @param populationId  人口id
+     * @return  人口详情
+     */
     PopulationDetailVO getPopulationDetailApp(@Param("populationId") Long populationId);
 
-    @Select("<script> " +
-            "SELECT " +
-            " *  " +
-            "FROM " +
-            " ( " +
-            " SELECT " +
-            " cmp.id, " +
-            "  cmp.`name` AS userName, " +
-            "  cmp.label, " +
-            "  cmp.card_no, " +
-            "  cmp.card_no_str, " +
-            "  cmp.sex, " +
-            "  cmp.address, " +
-            "  cmp.political_outlook, " +
-            "  cmp.census_register, " +
-            "  cmp.house_id, " +
-            "  cmp.phone, " +
-            "  IFNULL(cmp.house_id,0) as isHouse, " +
-            "  ( SELECT event_status FROM event_visiting_tasks WHERE event_status in (1,2,3,5) AND visiter_id = cmp.id ORDER BY create_at DESC LIMIT 1 ) AS eventStatus, " +
-            "  ( SELECT create_at FROM event_visiting_tasks WHERE event_status in (1,2,3,5) AND visiter_id = cmp.id ORDER BY create_at DESC LIMIT 1 ) AS createAt " +
-            " FROM " +
-            " com_mng_population AS cmp where 1=1 " +
-            "<if test='populationListDTO.keyWord != null and populationListDTO.keyWord != &quot;&quot;'>" +
-            "AND (cmp.name like concat (#{populationListDTO.keyWord},'%') or cmp.card_no_str like concat (#{populationListDTO.keyWord},'%') or cmp.address like concat (#{populationListDTO.keyWord},'%')) " +
-            " </if> " +
-            "<if test='populationListDTO.label != null and populationListDTO.label != &quot;&quot;'>" +
-            "AND cmp.label like concat ('%',#{populationListDTO.label},'%') " +
-            " </if> " +
-            "<if test='populationListDTO.sex != null'>" +
-            "AND cmp.sex = #{populationListDTO.sex} " +
-            " </if> " +
-            "<if test='populationListDTO.isHouse != null and populationListDTO.isHouse == 1'>" +
-            "AND cmp.house_id is not null " +
-            " </if> " +
-            "<if test='populationListDTO.isHouse != null and populationListDTO.isHouse == 2'>" +
-            "AND cmp.house_id is null " +
-            " </if> " +
-            "<if test='populationListDTO.communityId != null'>" +
-            "AND cmp.act_id = #{populationListDTO.communityId} " +
-            " </if> " +
-            "<if test='populationListDTO.politicalOutlook != null'>" +
-            "AND cmp.political_outlook = #{populationListDTO.politicalOutlook} " +
-            " </if> " +
-            " ) as population where 1=1 " +
-            "<if test='populationListDTO.eventStatus != null'>" +
-            "AND population.eventStatus = #{populationListDTO.eventStatus} " +
-            " </if> " +
-            " </script>")
-    IPage<ComMngPopulationListVO> getGridPopulationAdminList(Page page,@Param("populationListDTO") ComMngPopulationListDTO populationListDTO);
+    /**
+     * 根据人口id查询人口在各个社区的标签列表
+     * @param populationId  人口id
+     * @return  人口在各个社区的标签列表
+     */
+    List<ComMngPopulationCommunityTagsVo> getCommunityTagList(@Param("populationId") Long populationId);
+
+    /**
+     * 综治后台-分页查询居民列表
+     * @param page  分页参数
+     * @param populationListDTO 请求参数
+     * @return  居民列表
+     */
+    IPage<ComMngPopulationListVO> getGridPopulationAdminList(Page page,
+        @Param("populationListDTO") ComMngPopulationListDTO populationListDTO);
 
     @Select("select relation from com_mng_population_house_user where house_id = #{houseId} and popul_id = #{populationId}")
     Integer getPopulationRelationByHouseId(@Param("houseId") Long houseId, @Param("populationId") Long populationId);
 
-    @Select("<script>" +
-            " select count(id) from event_visiting_tasks as evt where visiter_id in " +
-            "<foreach collection='ids' item='id' index='index' open='(' close=')' separator=',' >" +
-            "#{id}" +
-            "</foreach>" +
-            " </script>")
+    @Select("<script>" + " select count(id) from event_visiting_tasks as evt where visiter_id in "
+        + "<foreach collection='ids' item='id' index='index' open='(' close=')' separator=',' >" + "#{id}"
+        + "</foreach>" + " </script>")
     Integer getPopulationVisitingCount(@Param("ids") List<Long> ids);
 
-    @Select("<script> " +
-            "SELECT " +
-            "   cmp.id, " +
-            "   cmp.`name`, " +
-            "   cmp.card_no as idCard, " +
-            "   cmp.label, " +
-            "   cmp.sex, " +
-            "   IFNULL( cmp.phone, '暂无' ) as phone, " +
-            "   cmp.address, " +
-            "   cmp.political_outlook " +
-            "  FROM " +
-            "   com_mng_population AS cmp where 1=1 " +
-            "<if test='populationDTO.keyWord != null'>" +
-            " AND (cmp.name like concat(#{populationDTO.keyWord},'%') or cmp.card_no_str like concat(#{populationDTO.keyWord},'%')) " +
-            " </if> " +
-            "<if test='populationDTO.populationIds != null and populationDTO.populationIds.size > 0'>" +
-            " AND cmp.id not in " +
-            "<foreach collection='populationDTO.populationIds' item='id' index='index' open='(' close=')' separator=',' >" +
-            "#{id}" +
-            "</foreach>" +
-            " </if> " +
-            " </script>")
-    IPage<EventSpecialPopulationVO> getBuildingHousePopulationList(Page page,@Param("populationDTO") PageComMngPopulationDTO populationDTO);
+    /**
+     * 综治后台删除居民,并清理人口与社区绑定关系
+     * @param ids   需要删除的人口id集合
+     */
+    void deletePopulaitonRelation(@Param("ids") List<Long> ids);
 
-    @Select("<script> " +
-            "SELECT " +
-            " count( id ) AS localNum, " +
-            " ( SELECT count( id ) FROM com_mng_population WHERE out_or_local = 2 " +
-            "<if test='communityId != null and communityId != 0'>" +
-            " AND act_id = #{communityId} " +
-            " </if> " +
-            " ) AS flowNum, " +
-            " ( SELECT count( id ) FROM com_mng_population WHERE label IS NOT NULL " +
-            "<if test='communityId != null and communityId != 0'>" +
-            " AND act_id = #{communityId} " +
-            " </if> " +
-            " ) AS specialNum  " +
-            "FROM " +
-            " com_mng_population  " +
-            "WHERE " +
-            " out_or_local = 1 " +
-            "<if test='communityId != null and communityId != 0'>" +
-            " AND act_id = #{communityId} " +
-            " </if> " +
-            " </script>")
+    @Select("<script> " + "SELECT " + "   cmp.id, " + "   cmp.`name`, " + "   cmp.card_no as idCard, "
+        + "   cmpct.label, " + "   cmp.sex, " + "   IFNULL( cmp.phone, '暂无' ) as phone, " + "   cmp.address, "
+        + "   cmp.political_outlook " + "  FROM "
+        + "   com_mng_population AS cmp left join com_mng_population_community_tags as cmpct on cmp.id = cmpct.population_id where 1=1 "
+        + "<if test='populationDTO.keyWord != null'>"
+        + " AND (cmp.name like concat(#{populationDTO.keyWord},'%') or cmp.card_no_str like concat(#{populationDTO.keyWord},'%')) "
+        + " </if> " + "<if test='populationDTO.populationIds != null and populationDTO.populationIds.size > 0'>"
+        + " AND cmp.id not in "
+        + "<foreach collection='populationDTO.populationIds' item='id' index='index' open='(' close=')' separator=',' >"
+        + "#{id}" + "</foreach>" + " </if> " + " </script>")
+    IPage<EventSpecialPopulationVO> getBuildingHousePopulationList(Page page,
+        @Param("populationDTO") PageComMngPopulationDTO populationDTO);
+
+    @Select("<script> " + "SELECT " + " count( id ) AS localNum, "
+        + " ( SELECT count( cmp.id ) FROM com_mng_population as cmp WHERE cmp.out_or_local = 2 "
+        +  " ) AS flowNum, "
+        + " ( SELECT count( cmpct.id ) FROM com_mng_population as cmp left join com_mng_population_community_tags AS cmpct on cmp.id = cmpct.population_id WHERE cmpct.label IS NOT NULL "
+        + " ) AS specialNum  " + "FROM "
+        + " com_mng_population as cmp  "
+        + "WHERE " + " cmp.out_or_local = 1 " + " </script>")
     PopulationStatisticsVO getGridPopulationStatistics(@Param("communityId") Long communityId);
 
-    @Select("<script> " +
-            "SELECT " +
-            " *  " +
-            "FROM " +
-            " ( " +
-            " SELECT " +
-            " cmp.id, " +
-            "  cmp.`name` AS userName, " +
-            "  cmp.label, " +
-            "  cmp.card_no, " +
-            "  cmp.card_no_str, " +
-            "  cmp.sex, " +
-            "  cmp.address, " +
-            "  cmp.political_outlook, " +
-            "  cmp.census_register, " +
-            "  cmp.house_id, " +
-            "  cmp.phone, " +
-            "  IFNULL(cmp.house_id,0) as isHouse, " +
-            "  ( SELECT event_status FROM event_visiting_tasks WHERE event_status in (1,2,3,5) AND visiter_id = cmp.id ORDER BY create_at DESC LIMIT 1 ) AS eventStatus, " +
-            "  ( SELECT create_at FROM event_visiting_tasks WHERE event_status in (1,2,3,5) AND visiter_id = cmp.id ORDER BY create_at DESC LIMIT 1 ) AS createAt " +
-            " FROM " +
-            " com_mng_population AS cmp where 1=1 " +
-            "<if test='populationExportDTO.keyWord != null and populationExportDTO.keyWord != &quot;&quot;'>" +
-            "AND (cmp.name like concat (#{populationExportDTO.keyWord},'%') or cmp.card_no_str like concat (#{populationExportDTO.keyWord},'%') or cmp.address like concat (#{populationExportDTO.keyWord},'%')) " +
-            " </if> " +
-            "<if test='populationExportDTO.label != null and populationExportDTO.label != &quot;&quot;'>" +
-            "AND cmp.label like concat ('%',#{populationExportDTO.label},'%') " +
-            " </if> " +
-            "<if test='populationExportDTO.sex != null'>" +
-            "AND cmp.sex = #{populationExportDTO.sex} " +
-            " </if> " +
-            "<if test='populationExportDTO.isHouse != null and populationExportDTO.isHouse == 1'>" +
-            "AND cmp.house_id is not null " +
-            " </if> " +
-            "<if test='populationExportDTO.populationIds != null and populationExportDTO.populationIds.size > 0'>" +
-            "AND cmp.id in  " +
-            "<foreach item='item' collection='populationExportDTO.populationIds' separator=',' open='(' close=')' index=''>" +
-            "#{item}" +
-            "</foreach>" +
-            " </if> " +
-            "<if test='populationExportDTO.isHouse != null and populationExportDTO.isHouse == 2'>" +
-            "AND cmp.house_id is null " +
-            " </if> " +
-            "<if test='populationExportDTO.communityId != null'>" +
-            "AND cmp.act_id = #{populationExportDTO.communityId} " +
-            " </if> " +
-            "<if test='populationExportDTO.politicalOutlook != null'>" +
-            "AND cmp.political_outlook = #{populationExportDTO.politicalOutlook} " +
-            " </if> " +
-            " ) as population where 1=1 " +
-            "<if test='populationExportDTO.eventStatus != null'>" +
-            "AND population.eventStatus = #{populationExportDTO.eventStatus} " +
-            " </if> " +
-            " </script>")
-    List<ComMngPopulationListVO> getGridPopulationAdminLists(@Param("populationExportDTO") ComMngPopulationExportDTO populationExportDTO);
+    @Select("<script> " + " SELECT " + " cmp.id, " + "  cmp.`name` AS userName, "
+        + "  cmpct.label, " + "  cmp.card_no, " + "  cmp.card_no_str, " + "  cmp.sex, " + "  cmp.address, "
+        + "  cmp.political_outlook, " + "  cmp.census_register, " + "  cmp.house_id, " + "  cmp.phone, "
+        + "  IFNULL(cmp.house_id,0) as isHouse, "
+        + "  ( SELECT event_status FROM event_visiting_tasks WHERE event_status in (1,2,3,5) AND visiter_id = cmp.id ORDER BY create_at DESC LIMIT 1 ) AS eventStatus, "
+        + "  ( SELECT create_at FROM event_visiting_tasks WHERE event_status in (1,2,3,5) AND visiter_id = cmp.id ORDER BY create_at DESC LIMIT 1 ) AS createAt "
+        + " FROM "
+        + " com_mng_population AS cmp left join com_mng_population_community_tags AS cmpct on cmp.id = cmpct.population_id where 1=1 "
+        + "<if test='populationExportDTO.keyWord != null and populationExportDTO.keyWord != &quot;&quot;'>"
+        + "AND (cmp.name like concat (#{populationExportDTO.keyWord},'%') or cmp.card_no_str like concat (#{populationExportDTO.keyWord},'%') or cmp.address like concat (#{populationExportDTO.keyWord},'%')) "
+        + " </if> " + "<if test='populationExportDTO.label != null and populationExportDTO.label != &quot;&quot;'>"
+        + "AND cmpct.label like concat ('%',#{populationExportDTO.label},'%') " + " </if> "
+        + "<if test='populationExportDTO.sex != null'>" + "AND cmp.sex = #{populationExportDTO.sex} " + " </if> "
+        + "<if test='populationExportDTO.isHouse != null and populationExportDTO.isHouse == 1'>"
+        + "AND cmp.house_id is not null " + " </if> "
+        + "<if test='populationExportDTO.populationIds != null and populationExportDTO.populationIds.size > 0'>"
+        + "AND cmp.id in  "
+        + "<foreach item='item' collection='populationExportDTO.populationIds' separator=',' open='(' close=')' index=''>"
+        + "#{item}" + "</foreach>" + " </if> "
+        + "<if test='populationExportDTO.isHouse != null and populationExportDTO.isHouse == 2'>"
+        + "AND cmp.house_id is null " + " </if> " + "<if test='populationExportDTO.communityId != null'>"
+        + "AND cmpct.community_id = ${populationExportDTO.communityId} " + " </if> "
+        + "<if test='populationExportDTO.politicalOutlook != null'>"
+        + "AND cmp.political_outlook = #{populationExportDTO.politicalOutlook} " + " </if> " + " </script>")
+    List<ComMngPopulationListVO>
+        getGridPopulationAdminLists(@Param("populationExportDTO") ComMngPopulationExportDTO populationExportDTO);
 
-    @Select("<script> " +
-            " select id,`name`,card_no,label from com_mng_population where 1=1 " +
-            "<if test='villagePopulationDTO.villageId != null'>" +
-            " and village_id = #{villagePopulationDTO.villageId} " +
-            " </if> " +
-            "<if test='villagePopulationDTO.keyWord != null'>" +
-            " AND (name like concat (#{villagePopulationDTO.keyWord},'%') or card_no_str like concat (#{villagePopulationDTO.keyWord},'%'))  " +
-            " </if> " +
-            "<if test='villagePopulationDTO.label != null and villagePopulationDTO.label != &quot;&quot;'>" +
-            " AND label like concat ('%',#{villagePopulationDTO.label},'%')  " +
-            " </if> " +
-            " </script>")
-    IPage<ComMngVillagePopulationListVO> getVillagePopulationAdmin(Page page,@Param("villagePopulationDTO") PageComMngVillagePopulationDTO villagePopulationDTO);
+    @Select("<script> "
+        + " select cmp.id,cmp.`name`,cmp.card_no,cmpct.label from com_mng_population as cmp left join com_mng_population_community_tags AS cmpct on cmp.id = cmpct.population_id where 1=1 "
+        + "<if test='villagePopulationDTO.villageId != null'>"
+        + " and cmp.village_id = #{villagePopulationDTO.villageId} " + " </if> "
+        + "<if test='villagePopulationDTO.keyWord != null'>"
+        + " AND (cmp.name like concat (#{villagePopulationDTO.keyWord},'%') or cmp.card_no_str like concat (#{villagePopulationDTO.keyWord},'%'))  "
+        + " </if> " + "<if test='villagePopulationDTO.label != null and villagePopulationDTO.label != &quot;&quot;'>"
+        + " AND cmpct.label like concat ('%',#{villagePopulationDTO.label},'%')  " + " </if> " + " </script>")
+    IPage<ComMngVillagePopulationListVO> getVillagePopulationAdmin(Page page,
+        @Param("villagePopulationDTO") PageComMngVillagePopulationDTO villagePopulationDTO);
 
+    @Insert("<script> "
+        + "insert into com_mng_population(`id`,`street_id`,`act_id`,`village_id`,`name`,`sex`,`certificate_type`,`card_no`"
+        + ",`card_no_expiration_date`,`card_no_str`,`road`,`door_no`,`floor`,`unit_no`,`house_no`,`political_outlook`"
+        + ",`work_company`,`special_situation`,`phone`,`out_or_local`,`census_register`,`person_type`,`country`"
+        + ",`date_of_departure`,`native_place`,`nation_code`,`nation`,`is_rent`,`culture_level`,`marriage`,`healthy`"
+        + ",`blood_type`,`religion`,`profession`,`person_status`,`death`,`head_portrait`,`monthly_income`,`family_status`"
+        + ",`birthday`,`goal_in_china`,`date_of_arrival`,`label`,`card_photo_front`,`card_photo_back`,`family_book`"
+        + ",`delete_flag`,`remark`,`create_at`,`update_at`,`residence`,`address`,`house_id`) values "
+        + "<foreach collection=\"populationList\" item=\"item\" index=\"index\" separator=\",\">\n"
+        + "        (#{item.id},#{item.streetId},#{item.actId},#{item.villageId}"
+        + ",#{item.name},#{item.sex},#{item.certificateType},#{item.cardNo}"
+        + ",#{item.cardNoExpirationDate},#{item.cardNoStr},#{item.road},#{item.doorNo}"
+        + ",#{item.floor},#{item.unitNo},#{item.houseNo},#{item.politicalOutlook}"
+        + ",#{item.workCompany},#{item.specialSituation},#{item.phone},#{item.outOrLocal}"
+        + ",#{item.censusRegister},#{item.personType},#{item.country},#{item.dateOfDeparture}"
+        + ",#{item.nativePlace},#{item.nationCode},#{item.nation},#{item.isRent},#{item.cultureLevel}"
+        + ",#{item.marriage},#{item.healthy},#{item.bloodType},#{item.religion},#{item.profession}"
+        + ",#{item.personStatus},#{item.death},#{item.headPortrait},#{item.monthlyIncome},#{item.familyStatus}"
+        + ",#{item.birthday},#{item.goalInChina},#{item.dateOfArrival},#{item.label},#{item.cardPhotoFront}"
+        + ",#{item.cardPhotoBack},#{item.familyBook},#{item.deleteFlag},#{item.remark},now(),#{item.updateAt}"
+        + ",#{item.residence},#{item.address},#{item.houseId})" + "    </foreach>" + " </script>")
+    void insertAll(@Param("populationList") List<ComMngPopulationDO> populationList);
+
+    void updateAll(@Param("populationList") List<ComMngPopulationDO> populationList);
+
+    /**
+     * 房屋二级联动
+     * @param communityId
+     * @return
+     */
+    List<VillageVO> getSecondHouseAddress(Long communityId);
+
+    /**
+     * 房屋二级联动后台
+     * @param communityId
+     * @return
+     */
+    List<VillageVO> getSecondHouse(Long communityId);
+
+    /**
+     * 四长四员分页查询
+     * @param page
+     * @param commonPage
+     * @return
+     */
+    IPage<ComMngPopulationNoSecretVO> query(Page page, @Param("commonPage") CommonPage commonPage);
+
+    /**
+     * 居民详情
+     */
+    ComMngPopulationDetailVO getById(Long id);
+
+    /**
+     * 修改实有人口绑定单元号
+     * @param villageId 小区id
+     * @param floor 楼栋号
+     * @param oldUnitNo 原单元号
+     * @param newUnitNo 新单元号
+     */
+    void updatePopulationUnit(@Param("villageId") Long villageId, @Param("floor") String floor,@Param("oldUnitNo") String oldUnitNo,@Param("newUnitNo") String newUnitNo);
+
+    /**
+     * 根据villageId查询特殊人群数
+     * @param villageId
+     * @param label
+     * @return
+     */
+    Integer selectCountByVillageId(@Param("villageId") Long villageId,@Param("label")String label);
+
+    CivilPartyStatisticsVO getCivilParty(@Param("communityId") Long communityId);
+
+    CivilGovernmentStatisticsVO getCivilGovernment(@Param("communityId") Long communityId);
+
+    CivilGridStatisticsVO getCivilGrid(@Param("communityId") Long communityId);
+
+    CivilConvenienceStatisticsVO getCivilConvenience(@Param("communityId") Long communityId);
+
+    /**
+     * 西区治理数据统计
+     * @return
+     */
+    WestScreenStatics westScreenStatics();
+
+    List<EventPopulationBasicsStatisticsVO> getBasicsList(@Param("streetId") Long streetId);
+
+    EventPopulationSpecialStatisticsVO getPopulationSpecial(@Param("streetId") Long streetId);
+
+    List<String> getPopulationListCardNo(@Param("streetId") Long streetId);
+
+    Integer getPopulationAge(@Param("streetId") Long streetId, @Param("age") Integer age);
+
+    List<EventPopulationStreetVO> getComprehensiveStreetList();
+
+    /**
+     * 基础数据统计
+     * @param communityId
+     * @return
+     */
+    BaseInfo baseInfo(Long communityId);
+
+    /**
+     * 业务数据统计
+     * @param communityId
+     * @return
+     */
+    IndexDynamic indexDynamic(Long communityId);
+
+    /**
+     * 大屏30天內事件数据
+     * @param communityId
+     * @return
+     */
+    List<EventGridIncidentStatisticsVO> getGridsGovernanceEventList(@Param("communityId") Long communityId);
+
+    /**
+     * 分页查询事件数据
+     * @param page
+     * @param pageBaseDTO
+     * @return
+     */
+    IPage<EventGridIncidentStatisticsVO> pageEventList(@Param("page") Page page, @Param("pageBaseDTO") PageBaseDTO pageBaseDTO);
+
+    /**
+     * 大屏事件详情新处理方式
+     * @param eventId
+     * @return
+     */
+    EventNewStatisticsVO getEventScreenSSPDateilNew(@Param("eventId") Long eventId);
 }

--
Gitblit v1.7.1