| 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; | 
| import com.panzhihua.common.model.dtos.grid.admin.ComMngPopulationListDTO; | 
| 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.screen.event.*; | 
| import com.panzhihua.common.model.vos.community.screen.index.*; | 
| import com.panzhihua.common.model.vos.grid.EventGridDataVO; | 
| import com.panzhihua.common.model.vos.grid.EventSpecialPopulationVO; | 
| import com.panzhihua.common.model.vos.grid.PopulationDetailVO; | 
| import com.panzhihua.common.model.vos.grid.PopulationListVO; | 
| import com.panzhihua.common.model.vos.grid.admin.ComMngPopulationListVO; | 
| 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.service_community.model.dos.ComMngPopulationDO; | 
|   | 
| /** | 
|  * 实有人口Dao | 
|  */ | 
| @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, " | 
|         + "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() != ""'>" | 
|         + "AND cmp.`name` LIKE concat(#{comMngPopulationVO.name},'%') " + " </if> " | 
|         + "<if test='comMngPopulationVO.road != null and comMngPopulationVO.road.trim() != ""'>" | 
|         + "AND cmp.road LIKE concat(#{comMngPopulationVO.road},'%') " + " </if> " | 
|         + "<if test='comMngPopulationVO.doorNo != null and comMngPopulationVO.doorNo.trim() != ""'>" | 
|         + "AND cmp.door_no = #{comMngPopulationVO.doorNo} " + " </if> " | 
|         + "<if test='comMngPopulationVO.alley != null and comMngPopulationVO.alley.trim() != ""'>" | 
|         + "AND cmv.alley LIKE concat(#{comMngPopulationVO.alley},'%') " + " </if> " | 
|         + "<if test='comMngPopulationVO.sex != null and comMngPopulationVO.sex.trim() != ""'>" | 
|         + "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() != ""'>" | 
|         + "AND cmp.native_place LIKE concat(#{comMngPopulationVO.nativePlace},'%') " + " </if> " | 
|         + "<if test='comMngPopulationVO.nation != null and comMngPopulationVO.nation.trim() != ""'>" | 
|         + "AND cmp.nation = #{comMngPopulationVO.nation} " + " </if> " | 
|         + "<if test='comMngPopulationVO.politicalOutlook != null and comMngPopulationVO.politicalOutlook.trim() != ""'>" | 
|         + "AND cmp.political_outlook = #{comMngPopulationVO.politicalOutlook} " + " </if> " | 
|         + "<if test='comMngPopulationVO.cardNo != null and comMngPopulationVO.cardNo.trim() != ""'>" | 
|         + "AND cmp.card_no = #{comMngPopulationVO.cardNo} " + " </if> " | 
|         + "<if test='comMngPopulationVO.remark != null and comMngPopulationVO.remark.trim() != ""'>" | 
|         + "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}") | 
|     List<ComHouseMemberVo> listHouseMermberByUserId(@Param("houseId") Long houseId, @Param("populId") Long populId); | 
|   | 
|     @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.`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 != ""'>" | 
| //        + "AND cmp.`name` LIKE concat(#{comMngPopulationVO.name},'%') " + " </if> " | 
| //        + "<if test='comMngPopulationVO.label != null and comMngPopulationVO.label != ""'>" | 
| //        + "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 != ""'>" | 
| //        + " and cmp.village_id = #{comMngPopulationVO.villageId} " + " </if> " | 
| //        + "<if test='comMngPopulationVO.road != null and comMngPopulationVO.road != ""'>" | 
| //        + "AND cmp.road = #{comMngPopulationVO.road} " + " </if> " | 
| //        + "<if test='comMngPopulationVO.doorNo != null and comMngPopulationVO.doorNo != ""'>" | 
| //        + "AND cmp.door_no = #{comMngPopulationVO.doorNo} " + " </if> " | 
| //        + "<if test='comMngPopulationVO.floor != null and comMngPopulationVO.floor != ""'>" | 
| //        + "AND cmp.floor = #{comMngPopulationVO.floor} " + " </if> " | 
| //        + "<if test='comMngPopulationVO.unitNo != null and comMngPopulationVO.unitNo != ""'>" | 
| //        + "AND cmp.unit_no = #{comMngPopulationVO.unitNo} " + " </if> " | 
| //        + "<if test='comMngPopulationVO.houseNo != null and comMngPopulationVO.houseNo != ""'>" | 
| //        + "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 != ""'>" | 
| //        + "AND cmp.sex = #{comMngPopulationVO.sex} " + " </if> " | 
| //        + "<if test='comMngPopulationVO.ageStartTime != null and comMngPopulationVO.ageStartTime != "" and comMngPopulationVO.ageEndTime == null'>" | 
| //        + "AND date_format(cmp.birthday,'%Y-%m-%d') <![CDATA[ <= ]]> #{comMngPopulationVO.ageStartTime} " + " </if> " | 
| //        + "<if test='comMngPopulationVO.ageEndTime != null and comMngPopulationVO.ageEndTime != "" 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 != "" '>" | 
| //        + "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 != ""'>" | 
| //        + "AND cmp.native_place LIKE concat(#{comMngPopulationVO.nativePlace},'%') " + " </if> " | 
| //        + "<if test='comMngPopulationVO.nation != null and comMngPopulationVO.nation != ""'>" | 
| //        + "AND cmp.nation = #{comMngPopulationVO.nation} " + " </if> " | 
| //        + "<if test='comMngPopulationVO.politicalOutlook != null and comMngPopulationVO.politicalOutlook != ""'>" | 
| //        + "AND cmp.political_outlook = #{comMngPopulationVO.politicalOutlook} " + " </if> " | 
| //        + "<if test='comMngPopulationVO.cardNo != null and comMngPopulationVO.cardNo != ""'>" | 
| //        + "AND cmp.card_no = #{comMngPopulationVO.cardNo} " + " </if> " | 
| //        + "<if test='comMngPopulationVO.remark != null and comMngPopulationVO.remark != ""'>" | 
| //        + "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); | 
|   | 
|     /** | 
|      * | 
|      * @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 != ""'>" | 
|         + " 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}") | 
|     UserElectronicFileVO getSysUserElectronicFile(@Param("idCard") String idCard); | 
|   | 
|     @Select("select user_id,card_photo_front,card_photo_back,family_book from sys_user where user_id=#{userId}") | 
|     UserElectronicFileVO getSysUserById(@Param("userId") Long userId); | 
|   | 
|     @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("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 = 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    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") | 
|     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}") | 
|     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 = 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}") | 
|     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}") | 
|     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}") | 
|     List<ComMngUserTagVO> getUserTagListByCommunityId(@Param("communityId") Long communityId); | 
|   | 
|     @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( id )  " + "FROM " + " com_mng_population_community_tags  " + "WHERE " | 
|             + " community_id = ${communityId} ") | 
|     Integer getSpecialStatistics(@Param("communityId") Long communityId); | 
|   | 
|     @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 != ""'>" | 
|         + " AND e.create_at <![CDATA[>=]]> #{screenEventDTO.startTime} " + " </if> " | 
|         + "<if test='screenEventDTO.endTime != null and screenEventDTO.endTime != ""'>" | 
|         + " 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 != ""'>" | 
|         + " AND e1.create_at <![CDATA[>=]]> #{screenEventDTO.startTime} " + " </if> " | 
|         + "<if test='screenEventDTO.endTime != null and screenEventDTO.endTime != ""'>" | 
|         + " 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 != ""'>" | 
|         + " AND e1.create_at <![CDATA[>=]]> #{screenEventDTO.startTime} " + " </if> " | 
|         + "<if test='screenEventDTO.endTime != null and screenEventDTO.endTime != ""'>" | 
|         + " 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); | 
|   | 
|     /** | 
|      * 综治事件大屏统计数据 | 
|      * @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") | 
|     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}") | 
|     List<EventGridStatisticsVO> getEventScreenGridData(@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 != ""'>" | 
|         + " AND e.create_at <![CDATA[>=]]> #{screenEventDTO.startTime} " + " </if> " | 
|         + "<if test='screenEventDTO.endTime != null and screenEventDTO.endTime != ""'>" | 
|         + " 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 != ""'>" | 
|         + " AND create_at <![CDATA[>=]]> #{screenEventDTO.startTime} " + " </if> " | 
|         + "<if test='screenEventDTO.endTime != null and screenEventDTO.endTime != ""'>" | 
|         + " 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_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}") | 
|     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}") | 
|     CivilVillageStatisticsVO getCivilScreenVillageStatistics(@Param("villageId") Long villageId); | 
|   | 
|     @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, 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(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 " + "(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 " + " 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}") | 
|     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}") | 
|     EventTransferRecordDetailVO getEventScreenEventTransDetailByCommunityId(@Param("communityId") Long communityId); | 
|   | 
|     @Select("select count(id) from com_elders_auth_elderly WHERE community_id = ${communityId}") | 
|     Integer getStatisticsCount(@Param("communityId") Long communityId); | 
|   | 
|     IPage<PopulationListVO> pagePopulationListApp(Page page, | 
|         @Param("populationListDTO") PagePopulationListDTO populationListDTO); | 
|   | 
|     /** | 
|      * 根据人口id查询人口详情 | 
|      * @param populationId  人口id | 
|      * @return  人口详情 | 
|      */ | 
|     PopulationDetailVO getPopulationDetailApp(@Param("populationId") Long populationId); | 
|   | 
|     /** | 
|      * 根据人口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>") | 
|     Integer getPopulationVisitingCount(@Param("ids") List<Long> ids); | 
|   | 
|     /** | 
|      * 综治后台删除居民,并清理人口与社区绑定关系 | 
|      * @param ids   需要删除的人口id集合 | 
|      */ | 
|     void deletePopulaitonRelation(@Param("ids") List<Long> ids); | 
|   | 
|     @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 " + " 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 != ""'>" | 
|         + "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 != ""'>" | 
|         + "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 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 != ""'>" | 
|         + " 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); | 
| } |