<?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="cn.iocoder.yudao.module.basic.dal.mysql.dealerinfo.DealerInfoMapper">

    <!--
        一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。
        无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。
        代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。
        文档可见:https://www.iocoder.cn/MyBatis/x-plugins/
     -->
    <resultMap id="BaseResultMap" type="cn.iocoder.yudao.module.basic.dal.dataobject.dealerinfo.DealerInfoDO">
        <id column="id" jdbcType="BIGINT" property="id"/>
        <result column="dealer_name" jdbcType="VARCHAR" property="dealerName"/>
        <result column="dealer_id" jdbcType="VARCHAR" property="dealerId"/>
        <result column="belong_business_id" jdbcType="BIGINT" property="belongBusinessId"/>
        <result column="belong_business_name" jdbcType="VARCHAR" property="belongBusinessName"/>
        <result column="business_code" jdbcType="VARCHAR" property="businessCode"/>
        <result column="contact_phone" jdbcType="VARCHAR" property="contactPhone"/>
        <result column="contact_name" jdbcType="VARCHAR" property="contactName"/>
        <result column="common_sale_area" jdbcType="VARCHAR" property="commonSaleArea"/>
        <result column="common_sale_area_id" jdbcType="VARCHAR" property="commonSaleAreaId"/>
        <result column="remarks" jdbcType="VARCHAR" property="remarks"/>
        <result column="create_time" jdbcType="TIMESTAMP" property="createTime"/>
    </resultMap>

    <select id="selectPageByInfo" resultMap="BaseResultMap">
        select bdi.*,bbi.id,bbi.business_name from basic_dealer_info bdi
        left join basic_business_info bbi on bbi.id = bdi.belong_business_id
        ${ew.customSqlSegment}
        order by bdi.id DESC
    </select>

    <select id="getDealerInfoByGoods" resultType="cn.iocoder.yudao.module.basic.dal.dataobject.dealerinfo.DealerInfoDO">
        select bdi.*
        from basic_dealer_info bdi
        left join basic_dealer_goods bdg on bdg.dealer_id = bdi.dealer_id
        <where>
            bdi.deleted = 0 and bdg.deleted = 0
            and bdi.belong_business_id = #{businessInfoId} and bdg.goods_id = #{goodsId}
            <if test="dealerId != null and dealerId != ''">and bdi.dealer_id =#{dealerId}</if>
        </where>
        group by bdi.id
    </select>
</mapper>