|  |  |  | /** | 
					
						
							|  |  |  |  * Copyright 2018 人人开源 https://www.renren.io
 | 
					
						
							|  |  |  |  * <p> | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * <p> | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * <p> | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package com.epmet.dao; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import com.epmet.commons.mybatis.dao.BaseDao; | 
					
						
							|  |  |  | import com.epmet.commons.tools.dto.result.OptionDataResultDTO; | 
					
						
							|  |  |  | import com.epmet.dto.IcResiUserDTO; | 
					
						
							|  |  |  | import com.epmet.dto.form.ResiUserQueryValueDTO; | 
					
						
							|  |  |  | import com.epmet.dto.result.*; | 
					
						
							|  |  |  | import com.epmet.entity.IcResiUserEntity; | 
					
						
							|  |  |  | import org.apache.ibatis.annotations.MapKey; | 
					
						
							|  |  |  | import org.apache.ibatis.annotations.Mapper; | 
					
						
							|  |  |  | import org.apache.ibatis.annotations.Param; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import java.math.BigDecimal; | 
					
						
							|  |  |  | import java.util.List; | 
					
						
							|  |  |  | import java.util.Map; | 
					
						
							|  |  |  | import java.util.Set; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * 用户基础信息 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @author generator generator@elink-cn.com | 
					
						
							|  |  |  |  * @since v1.0.0 2021-10-26 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | @Mapper | 
					
						
							|  |  |  | public interface IcResiUserDao extends BaseDao<IcResiUserEntity> { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @Author sun | 
					
						
							|  |  |  |      * @Description 居民信息各表新增数据 | 
					
						
							|  |  |  |      **/ | 
					
						
							|  |  |  |     void add(@Param("tableName") String tableName, @Param("map") Map<String, String> map); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @Author sun | 
					
						
							|  |  |  |      * @Description 更新或新增居民信息各表数据 | 
					
						
							|  |  |  |      **/ | 
					
						
							|  |  |  |     void upTable(@Param("tableName") String tableName, @Param("id") String id, @Param("map") Map<String, ?> map); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     List<Map<String,Object>> selectListResiMap(@Param("customerId") String customerId, | 
					
						
							|  |  |  |                                                @Param("formCode") String formCode, | 
					
						
							|  |  |  |                                                @Param("conditions") List<ResiUserQueryValueDTO> conditions, | 
					
						
							|  |  |  |                                                @Param("resultColumns") List<IcFormResColumnDTO> resultColumns, | 
					
						
							|  |  |  |                                                @Param("subTables") List<String> subTables, | 
					
						
							|  |  |  |                                                @Param("currentStaffAgencyId")String currentStaffAgencyId, | 
					
						
							|  |  |  |                                                @Param("staffOrgPath") String staffOrgPath, | 
					
						
							|  |  |  |                                                @Param("resultTableName")String resultTableName, | 
					
						
							|  |  |  |                                                @Param("keyword") String keyword); | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 查询主表 | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param icResiUserId | 
					
						
							|  |  |  |      * @return java.util.List<java.util.Map < java.lang.String, java.lang.Object>> | 
					
						
							|  |  |  |      * @author yinzuomei | 
					
						
							|  |  |  |      * @date 2021/10/28 11:20 上午 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<Map<String, Object>> selectListMapById(@Param("customerId") String customerId, | 
					
						
							|  |  |  |                                                 @Param("icResiUserId") String icResiUserId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 根据ic_resi_user.id去查询各个子表记录,动态传入表名 | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param icResiUserId | 
					
						
							|  |  |  |      * @param subTableName | 
					
						
							|  |  |  |      * @return java.util.List<java.util.Map < java.lang.String, java.lang.Object>> | 
					
						
							|  |  |  |      * @author yinzuomei | 
					
						
							|  |  |  |      * @date 2021/10/28 11:19 上午 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<Map<String, Object>> selectSubTableRecords(@Param("customerId") String customerId, | 
					
						
							|  |  |  |                                                     @Param("icResiUserId") String icResiUserId, | 
					
						
							|  |  |  |                                                     @Param("subTableName") String subTableName); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     int updateToDel(String icResiUserId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     int updateSubTableToDel(@Param("subTalbeName") String subTalbeName, @Param("icResiUserId") String icResiUserId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 接口名称 | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param customerId      客户id | 
					
						
							|  |  |  |      * @param resultTableName 获取哪个表的数据??? | 
					
						
							|  |  |  |      * @param conditions      前端传入的查询入参 | 
					
						
							|  |  |  |      * @return java.util.List<java.util.Map < java.lang.String, java.lang.Object>> | 
					
						
							|  |  |  |      * @author yinzuomei | 
					
						
							|  |  |  |      * @date 2021/11/2 10:35 上午 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<Map<String, Object>> dynamicQuery(@Param("customerId") String customerId, | 
					
						
							|  |  |  |                                            @Param("resultTableName") String resultTableName, | 
					
						
							|  |  |  |                                            @Param("conditions") List<ResiUserQueryValueDTO> conditions, | 
					
						
							|  |  |  |                                            @Param("subTables") List<String> subTables, | 
					
						
							|  |  |  |                                            @Param("currentStaffAgencyId") String currentStaffAgencyId, | 
					
						
							|  |  |  |                                            @Param("staffOrgPath") String staffOrgPath); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param userId | 
					
						
							|  |  |  |      * @Description 查询个人信息 | 
					
						
							|  |  |  |      * @author zxc | 
					
						
							|  |  |  |      * @date 2021/11/3 10:28 上午 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     PersonDataResultDTO personData(@Param("userId") String userId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param name | 
					
						
							|  |  |  |      * @param agencyId | 
					
						
							|  |  |  |      * @Description 根据名字,组织查询人 | 
					
						
							|  |  |  |      * @author zxc | 
					
						
							|  |  |  |      * @date 2021/11/3 2:05 下午 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<SearchByNameResultDTO> searchByName(@Param("name") String name, @Param("agencyId") String agencyId, @Param("pageNo") Integer pageNo); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Set<String> selectUserDemandCode(String icResiUserId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     String selectCategoryNames(@Param("customerId") String customerId, @Param("codeSet") Set<String> codeSet); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @MapKey("HOME_ID") | 
					
						
							|  |  |  |     Map<String, Map<String, String>> getHomeUserCategoryCount(@Param("buildId") String buildId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param userId | 
					
						
							|  |  |  |      * @Description 根据userId查询志愿者 | 
					
						
							|  |  |  |      * @author zxc | 
					
						
							|  |  |  |      * @date 2021/11/5 5:44 下午 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<String> selectVolunteerByUserId(@Param("userId") String userId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param columns | 
					
						
							|  |  |  |      * @Description 查询人员类别 | 
					
						
							|  |  |  |      * @author zxc | 
					
						
							|  |  |  |      * @date 2021/11/8 1:50 下午 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     Map<String, String> selectPersonType(@Param("columns") List<String> columns, @Param("customerId") String customerId, | 
					
						
							|  |  |  |                                          @Param("tableName") String tableName, @Param("userId") String userId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @Author sun | 
					
						
							|  |  |  |      * @Description 查询居民信息 | 
					
						
							|  |  |  |      **/ | 
					
						
							|  |  |  |     IcResiUserDTO getResiUser(IcResiUserDTO dto); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param agencyId | 
					
						
							|  |  |  |      * @param gridId | 
					
						
							|  |  |  |      * @param name | 
					
						
							|  |  |  |      * @return | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<DemandUserResDTO> selectDemandUsers(@Param("agencyId") String agencyId, | 
					
						
							|  |  |  |                                              @Param("gridId") String gridId, | 
					
						
							|  |  |  |                                              @Param("name") String name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IcResiUserDTO selectIdByIdCard(@Param("customerId") String customerId, | 
					
						
							|  |  |  |                                    @Param("idNum") String idNum, | 
					
						
							|  |  |  |                                    @Param("icResiUserId") String icResiUserId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 获取居民名称,家属名称和id | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param isResiUserId | 
					
						
							|  |  |  |      * @return | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     IcResiUserBriefDTO selectIcResuUser(@Param("isResiUserId") String isResiUserId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 除了本人以外,住在这个房子的人 | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param currentIcResiUserId | 
					
						
							|  |  |  |      * @param homeId | 
					
						
							|  |  |  |      * @return | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<HouseUserDTO> selectListFamilyMember(@Param("currentIcResiUserId") String currentIcResiUserId, @Param("homeId") String homeId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 组织内党员年龄范围统计 | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @Param orgType | 
					
						
							|  |  |  |      * @Param orgId | 
					
						
							|  |  |  |      * @Return {@link List< OptionDataResultDTO>} | 
					
						
							|  |  |  |      * @Author zhaoqifeng | 
					
						
							|  |  |  |      * @Date 2021/12/10 17:11 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<OptionDataResultDTO> getPartyMemberAgeStatistics(@Param("orgType") String orgType, @Param("orgId") String orgId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 获取年龄范围内党员列表 | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @Param orgType | 
					
						
							|  |  |  |      * @Param orgId | 
					
						
							|  |  |  |      * @Param min | 
					
						
							|  |  |  |      * @Param max | 
					
						
							|  |  |  |      * @Return {@link List< PartyMemberAgeResultDTO>} | 
					
						
							|  |  |  |      * @Author zhaoqifeng | 
					
						
							|  |  |  |      * @Date 2021/12/10 17:11 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<PartyMemberAgeResultDTO> getPartyMemberAgeList(@Param("orgType") String orgType, @Param("orgId") String orgId, | 
					
						
							|  |  |  |                                                         @Param("code") String code); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 党员文化程度统计 | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @Param orgType | 
					
						
							|  |  |  |      * @Param orgId | 
					
						
							|  |  |  |      * @Return {@link List< OptionDataResultDTO>} | 
					
						
							|  |  |  |      * @Author zhaoqifeng | 
					
						
							|  |  |  |      * @Date 2021/12/10 17:29 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<OptionDataResultDTO> getPartyMemberEducationStatistics(@Param("orgType") String orgType, @Param("orgId") String orgId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 按教育程度获取党员列表 | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @Param orgType | 
					
						
							|  |  |  |      * @Param orgId | 
					
						
							|  |  |  |      * @Param code | 
					
						
							|  |  |  |      * @Return {@link List< PartyMemberAgeResultDTO>} | 
					
						
							|  |  |  |      * @Author zhaoqifeng | 
					
						
							|  |  |  |      * @Date 2021/12/10 17:24 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<PartyMemberEducationResultDTO> getPartyMemberEducationList(@Param("orgType") String orgType, @Param("orgId") String orgId, | 
					
						
							|  |  |  |                                                                     @Param("code") String code); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     List<VolunteerDistributionResultDTO.Distribution> listIcResiInfosByUserIds(@Param("userIds") List<String> userIds); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Map<String, String> getCategoryListMap(@Param("columns")List<String> columns, @Param("icUserId") String icUserId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Map<String, String> selectResiInfoMap(@Param("idCard") String idCard, @Param("resiId") String resiId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     List<Map<String,Object>> selectResiUsers(@Param("types")List<String> types,@Param("orgId")String orgId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     List<String> icUserCustomerIds(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     List<Map<String, String>> getIcUserList(@Param("customerId") String customerId); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * desc: 获取数据分析列中的 各类居民数据 | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param customerId | 
					
						
							|  |  |  |      * @param tableName | 
					
						
							|  |  |  |      * @param columnList | 
					
						
							|  |  |  |      * @param id 非必填 leve有值时 必填 | 
					
						
							|  |  |  |      * @param level 非必填 | 
					
						
							|  |  |  |      * @return java.util.Map<java.lang.String,java.math.BigDecimal> 字段名:数量 | 
					
						
							|  |  |  |      * @author LiuJanJun | 
					
						
							|  |  |  |      * @date 2022/2/12 3:03 下午 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     Map<String, BigDecimal> getDataAnalyseCount(@Param("customerId") String customerId, @Param("tableName") String tableName, | 
					
						
							|  |  |  |                                                 @Param("columnList") List<String> columnList, @Param("id") String id, @Param("level") String level); | 
					
						
							|  |  |  |     List<Map<String, String>> getIcUserList(@Param("customerId") String customerId, @Param("columns")List<String> columns); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Desc: 根据房屋IDs查询房屋下是否有存在居民的 | 
					
						
							|  |  |  |      * @param ids | 
					
						
							|  |  |  |      * @author zxc | 
					
						
							|  |  |  |      * @date 2022/3/2 10:32 上午 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     List<String> getExistUserByHouseIds(@Param("ids") List<String> ids); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |