zoukankan      html  css  js  c++  java
  • mybatis-地区三表生成地区树

    package com.dhht.manager.vo.area;

    import lombok.Data;

    import java.io.Serializable;
    import java.util.List;

    /**
    * @Author: sh
    * @Description: ProvinceVO
    * @Date: 19:33 2019/12/23
    */
    @Data
    public class ProvinceVO implements Serializable {
    private static final long serialVersionUID = 8581900297888963919L;
    private Long id;
    private String name;
    private String code;
    private Long regionLevel;
    private String regionName;
    private Long parentId;
    private List<CityVO> children;
    }

    package com.dhht.manager.vo.area;

    import lombok.Data;

    import java.io.Serializable;
    import java.util.List;

    /**
    * @Author: sh
    * @Description: CityVO
    * @Date: 19:33 2019/12/23
    */
    @Data
    public class CityVO implements Serializable {
    private static final long serialVersionUID = -4506315529106267971L;
    private Long id;
    private String name;
    private String code;
    private Long regionLevel;
    private String regionName;
    private Long parentId;
    private List<DistrictVO> children;
    }

    package com.dhht.manager.vo.area;

    import lombok.Data;

    import java.io.Serializable;
    import java.util.List;

    /**
    * @Author: sh
    * @Description: DistrictVO
    * @Date: 19:35 2019/12/23
    */
    @Data
    public class DistrictVO implements Serializable {
    private static final long serialVersionUID = 6682075711606147829L;

    private Long id;
    private String name;
    private String code;
    private Long regionLevel;
    private String regionName;
    private Long parentId;
    private List<Object> children;
    }

    package com.dhht.dao;

    import com.dhht.manager.vo.area.DistrictVO;
    import com.dhht.manager.vo.area.ProvinceVO;
    import com.dhht.model.City;
    import org.apache.ibatis.annotations.Param;

    import java.util.List;

    public interface CityMapper {

    List<ProvinceVO> treeProvinceQuery(@Param(value = "code")String code);

    List<City> treeCityQuery(@Param(value = "id")Long id);

    List<DistrictVO> treeDistrictQuery(@Param(value = "id")Long id);
    }


    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    <mapper namespace="com.dhht.dao.CityMapper">
    <!--province-->
    <resultMap id="provinceVoMap" type="com.dhht.manager.vo.area.ProvinceVO">
    <id column="id" jdbcType="BIGINT" property="id" />
    <result column="name" jdbcType="VARCHAR" property="name" />
    <result column="code" jdbcType="VARCHAR" property="code" />
    <result column="parentId" jdbcType="BIGINT" property="parentId" />
    <collection property="children" column="id" select="com.dhht.dao.CityMapper.treeCityQuery"></collection>
    </resultMap>
    <!--end province-->

    <!--city-->
    <resultMap id="cityVoMap" type="com.dhht.manager.vo.area.CityVO">
    <id column="id" jdbcType="BIGINT" property="id" />
    <result column="name" jdbcType="VARCHAR" property="name" />
    <result column="code" jdbcType="VARCHAR" property="code" />
    <result column="parentId" jdbcType="BIGINT" property="parentId" />
    <collection property="children" column="id" select="com.dhht.dao.CityMapper.treeDistrictQuery"></collection>
    </resultMap>
    <!--end city-->

    <!--district-->
    <resultMap id="districtVoMap" type="com.dhht.manager.vo.area.DistrictVO">
    <id column="id" jdbcType="BIGINT" property="id" />
    <result column="name" jdbcType="VARCHAR" property="name" />
    <result column="code" jdbcType="VARCHAR" property="code" />
    <result column="parentId" jdbcType="BIGINT" property="parentId" />
    </resultMap>
    <!--end district-->
    <resultMap id="BaseResultMap" type="com.dhht.model.City">
    <id column="id" jdbcType="BIGINT" property="id" />
    <result column="name" jdbcType="VARCHAR" property="name" />
    <result column="province_id" jdbcType="BIGINT" property="provinceId" />
    <result column="code" jdbcType="VARCHAR" property="code" />
    </resultMap>

    <select id="treeProvinceQuery" resultMap="provinceVoMap">
    select id,name,code,NULL AS parentId
    from lv_province
    WHERE CODE=#{code}
    </select>

    <select id="treeCityQuery" resultMap="cityVoMap">
    select id,name,code,#{id} AS parentId
    from lv_city
    WHERE province_id=#{id}
    </select>

    <select id="treeDistrictQuery" resultMap="districtVoMap">
    select id,name,code,#{id} AS parentId
    from lv_district
    WHERE city_id=#{id}
    </select>
    </mapper>
  • 相关阅读:
    NET 4.+ & .NET CORE 高性能 轻量级 ORM框架,众多.NET框架中最容易使用的数据库访问技术
    mvc cookie
    正则表达式捕获带有属性的标签
    IT第十天
    代码段
    关于java.lang中String类的学习:最特殊的数据类型(持续整理中......)
    关于String.concat()方法和StringBuffer.append()方法的学习:方法是如何追加字符到源字符串的
    关于String和StringBuffer的理解问题:指针、变量的声明、变量的值的变化
    关于字符串检索、关键词的搜索问题:已搜索过的部分不会再被纳入下次搜索的范围内
    IT第九天
  • 原文地址:https://www.cnblogs.com/sung1024/p/12128010.html
Copyright © 2011-2022 走看看