| package com.panzhihua.service_community.dao; | 
|   | 
| import java.util.List; | 
|   | 
| import com.panzhihua.common.model.vos.community.ComActPasswordVo; | 
| import org.apache.ibatis.annotations.Mapper; | 
| import org.apache.ibatis.annotations.Param; | 
| import org.apache.ibatis.annotations.Select; | 
| import org.apache.ibatis.annotations.Update; | 
|   | 
| 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.PageComActDTO; | 
| import com.panzhihua.common.model.dtos.community.switchs.SearchCommunityDTO; | 
| import com.panzhihua.common.model.vos.community.ComActVO; | 
| import com.panzhihua.common.model.vos.community.ComPopulationActVO; | 
| import com.panzhihua.common.model.vos.community.switchs.CommunitySwitchAllAppletsVO; | 
| import com.panzhihua.common.model.vos.community.switchs.StreetAllAppletsVO; | 
| import com.panzhihua.common.model.vos.grid.EventGridCommunityAdminVO; | 
| import com.panzhihua.service_community.model.dos.ComActDO; | 
|   | 
| /** | 
|  * @program: springcloud_k8s_panzhihuazhihuishequ | 
|  * @description: 社区 | 
|  * @author: huang.hongfa weixin hhf9596 qq 959656820 | 
|  * @create: 2020-12-07 14:13 | 
|  **/ | 
| @Mapper | 
| public interface ComActDAO extends BaseMapper<ComActDO> { | 
|     // @Select("<script> " + | 
|     // " <where>" + | 
|     // "<if test='nameCn != null and nameCn.trim() != ""'>" + | 
|     // " </if> " + | 
|     // "<if test='nameCn != null and nameCn.trim() != ""'>" + | 
|     // " </if> " + | 
|     // "<if test='nameCn != null and nameCn.trim() != ""'>" + | 
|     // " </if> " + | 
|     // " </where>" + | 
|     // "</script>") | 
|   | 
|     @Select("<script> " + "SELECT\n" + "c.community_id,\n" + "c.`name`,\n" | 
|         + "ST_Distance_Sphere ( Point ( #{lng}, #{lat} ), Point ( c.lng, c.lat ) ) AS distance \n" + "FROM\n" | 
|         + "com_act c \n" + " <where>" + "<if test='areaCode != null and areaCode.trim() != ""'>" | 
|         + "c.area_code = #{areaCode} \n" + " </if> " + " </where>" + "ORDER BY\n" + "distance ASC" | 
|         + "<if test='lng != null and lng.trim() != ""'>" + " limit 100 " + " </if> " + "</script>") | 
|     List<ComActVO> listCommunity(ComActVO comActVO); | 
|   | 
|     @Select("select district_name from com_mng_struct_area_district where district_adcode=#{areaCode}") | 
|     String selectAreaName(String areaCode); | 
|   | 
|     @Select("<script> " + "SELECT\n" + "a.* \n" + "FROM\n" + "com_act a \n" + " <where>" | 
|         + "<if test='pageComActDTO.name != null and pageComActDTO.name.trim() != ""'>" | 
|         + "and a.name LIKE concat( #{pageComActDTO.name}, '%' ) \n" + " </if> " | 
|         + "<if test='pageComActDTO.areaCode != null and pageComActDTO.areaCode.trim() != ""'>" | 
|         + "AND a.area_code = #{pageComActDTO.areaCode} \n" + " </if> " | 
|         + "<if test='pageComActDTO.createAtBegin != null '>" + "AND a.create_at BETWEEN " | 
|         + "#{pageComActDTO.createAtBegin} \n" + "AND #{pageComActDTO.createAtEnd}" + " </if> " + " </where>" | 
|         + " order by a.create_at desc" + "</script>") | 
|     IPage<ComActVO> pageCommunity(Page page, @Param("pageComActDTO") PageComActDTO pageComActDTO); | 
|   | 
|     @Update("update sys_user u set u.password=#{password} where u.account=#{account} and u.type=3 and u.community_id = ${communityId}") | 
|     void updateAccountPassword(@Param("password") String password, @Param("account") String account, | 
|         @Param("communityId") Long communityId); | 
|   | 
|     @Select("select community_id,`name`,lng,lat from com_act where state = 0") | 
|     List<EventGridCommunityAdminVO> getCommunityLists(); | 
|   | 
|     @Select("select ca.`name`,cmsap.province_name,cmsac.city_name,cmsad.district_name,ca.street_id,ca.community_id,cs.`name` as streetName from com_act as ca \n" | 
|         + "left join com_mng_struct_area_province as cmsap on cmsap.province_adcode = ca.province_code\n" | 
|         + "left join com_mng_struct_area_city as cmsac on cmsac.city_adcode = ca.city_code\n" | 
|         + "left join com_mng_struct_area_district as cmsad on cmsad.district_adcode = ca.area_code\n" | 
|         + "left join com_street as cs on cs.street_id = ca.street_id\n" + "where ca.community_id = ${communityId}") | 
|     ComPopulationActVO getPopulationActById(@Param("communityId") Long communityId); | 
|   | 
|     @Select("select `name`,street_id from com_street order by area_code asc") | 
|     List<StreetAllAppletsVO> getStreetList(String areaCode); | 
|   | 
|     @Select("select ca.`name`,ca.street_id,ca.community_id,cs.`name` as streetName from com_act as ca left join com_street as cs on cs.street_id = ca.street_id where ca.state = 0 and ca.street_id = #{streetId}") | 
|     List<CommunitySwitchAllAppletsVO> getCommunityListByStreetId(@Param("streetId") Long streetId); | 
|   | 
|     @Select("<script> select ca.`name`,ca.street_id,ca.community_id,cs.`name` as streetName " + | 
|             "from com_act as ca " + | 
|             "left join com_street as cs on cs.street_id = ca.street_id " + | 
|             "where ca.state = 0 and ca.name like concat('%',#{name},'%') <if test='areaCode !=null and areaCode !=""'> and cs.area_code = #{areaCode} </if> </script> ") | 
|     List<CommunitySwitchAllAppletsVO> getCommunityListByName(@Param("name") String name,@Param("areaCode") String areaCode); | 
|   | 
|     @Select("SELECT   c.community_id,    c.`name`,    c.street_id,    cs.`name` as streetName," + | 
|             "round( ST_Distance_Sphere ( Point ( #{communityDTO.longitude}, #{communityDTO.latitude} ), Point ( c.lng, c.lat ) )/ 1000, 2 ) AS distance  " + | 
|             "FROM    com_act c     left join com_street as cs on cs.street_id = c.street_id  " + | 
|             "where cs.area_code = #{communityDTO.areaCode} " + | 
|             "HAVING distance >= 0 and distance <= #{communityDTO.distance}   ORDER BY    distance ASC") | 
|     List<CommunitySwitchAllAppletsVO> getCommunityListByNearby(@Param("communityDTO") SearchCommunityDTO communityDTO); | 
|   | 
|     @Select("<script> select community_id,name,lng,lat from com_act  where state = 0 <if test='areaCode !=null'> and area_code = #{areaCode} </if> </script>") | 
|     List<EventGridCommunityAdminVO> getWestCommunityLists(@Param("areaCode") String areCode); | 
|   | 
|     @Select("select account,plaintext_password as password from com_act where community_id = ${communityId}") | 
|     ComActPasswordVo getCommunityPassword(@Param("communityId") Long communityId); | 
| } |