yujian
2020-06-09 554de444b87aab5f93cb1593a8095612cf9479a7
fanli/src/main/java/com/yeshi/fanli/mapping/user/ForbiddenUserIdentifyCodeMapper.xml
@@ -1,179 +1,99 @@
<?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.yeshi.fanli.dao.mybatis.user.ForbiddenUserIdentifyCodeMapper">
   <resultMap id="BaseResultMap"
      type="com.yeshi.fanli.entity.bus.user.ForbiddenUserIdentifyCode">
      <id column="fuc_id" property="id" jdbcType="BIGINT" />
      <result column="fuc_type" property="type"
         typeHandler="com.yeshi.fanli.util.mybatishandler.ForbiddenUserIdentifyCodeTypeEnumHandler" />
      <result column="fuc_uid" property="user" jdbcType="VARCHAR" />
      <result column="fuc_identify_code" property="identifyCode"
         jdbcType="VARCHAR" />
      <result column="fuc_effective" property="effective" jdbcType="BOOLEAN" />
      <result column="fuc_create_time" property="createTime"
         jdbcType="TIMESTAMP" />
      <result column="fuc_update_time" property="updateTime"
         jdbcType="TIMESTAMP" />
   </resultMap>
   <resultMap id="BaseResultMapVO" type="com.yeshi.fanli.vo.user.ForbiddenUserIdentifyCodeVO">
      <result column="f_wxUnionId" property="f_wxUnionId"   jdbcType="VARCHAR" />
      <result column="f_taobaoUid" property="f_taobaoUid"   jdbcType="VARCHAR" />
      <result column="f_phone" property="f_phone"   jdbcType="VARCHAR" />
      <result column="f_alipayAccount" property="f_alipayAccount"   jdbcType="VARCHAR" />
      <result column="alipayAccount" property="alipayAccount"   jdbcType="VARCHAR" />
      <result column="alipayAccountName" property="alipayAccountName"   jdbcType="VARCHAR" />
      <association property="userInfo" column="id"
          resultMap="com.yeshi.fanli.dao.mybatis.UserInfoMapper.BaseResultMap"/>
   </resultMap>
   <sql id="Base_Column_List">fuc_id,fuc_type,fuc_identify_code,fuc_effective,fuc_create_time,fuc_update_time,fuc_beizhu
   </sql>
   <select id="selectByPrimaryKey" resultMap="BaseResultMap"
      parameterType="java.lang.Long">
      select
      <include refid="Base_Column_List" />
      from yeshi_ec_forbidden_user_identify_code where fuc_id =
      #{id,jdbcType=BIGINT}
   </select>
   <select id="listByTypeAndIdentifyCode" resultMap="BaseResultMap">
      select
      <include refid="Base_Column_List" />
      from yeshi_ec_forbidden_user_identify_code where fuc_type =
      #{type} and
      fuc_identify_code=#{identifyCode}
   </select>
   <delete id="deleteByPrimaryKey" parameterType="java.lang.Long">delete from
      yeshi_ec_forbidden_user_identify_code where fuc_id =
      #{id,jdbcType=BIGINT}
   </delete>
   <insert id="insert"
      parameterType="com.yeshi.fanli.entity.bus.user.ForbiddenUserIdentifyCode"
      useGeneratedKeys="true" keyProperty="id">insert into
      yeshi_ec_forbidden_user_identify_code
      (fuc_id,fuc_type,fuc_identify_code,fuc_effective,fuc_create_time,fuc_update_time,fuc_beizhu)
      values
      (#{id,jdbcType=BIGINT},#{type,jdbcType=VARCHAR},#{identifyCode,jdbcType=VARCHAR},#{effective,jdbcType=BOOLEAN},#{createTime,jdbcType=TIMESTAMP},#{updateTime,jdbcType=TIMESTAMP},#{beiZhu,jdbcType=VARCHAR})
   </insert>
   <insert id="insertSelective"
      parameterType="com.yeshi.fanli.entity.bus.user.ForbiddenUserIdentifyCode"
      useGeneratedKeys="true" keyProperty="id">
      insert into yeshi_ec_forbidden_user_identify_code
      <trim prefix="(" suffix=")" suffixOverrides=",">
         <if test="id != null">fuc_id,</if>
         <if test="type != null">fuc_type,</if>
         <if test="identifyCode != null">fuc_identify_code,</if>
         <if test="effective != null">fuc_effective,</if>
         <if test="createTime != null">fuc_create_time,</if>
         <if test="updateTime != null">fuc_update_time,</if>
         <if test="beiZhu != null">fuc_beizhu,</if>
      </trim>
      values
      <trim prefix="(" suffix=")" suffixOverrides=",">
         <if test="id != null">#{id,jdbcType=BIGINT},</if>
         <if test="type != null">#{type,jdbcType=VARCHAR},</if>
         <if test="identifyCode != null">#{identifyCode,jdbcType=VARCHAR},</if>
         <if test="effective != null">#{effective,jdbcType=BOOLEAN},</if>
         <if test="createTime != null">#{createTime,jdbcType=TIMESTAMP},</if>
         <if test="updateTime != null">#{updateTime,jdbcType=TIMESTAMP},</if>
         <if test="beiZhu != null">#{beiZhu,jdbcType=VARCHAR},</if>
      </trim>
   </insert>
   <update id="updateByPrimaryKey"
      parameterType="com.yeshi.fanli.entity.bus.user.ForbiddenUserIdentifyCode">update yeshi_ec_forbidden_user_identify_code set
      fuc_type = #{type,jdbcType=VARCHAR},fuc_identify_code =
      #{identifyCode,jdbcType=VARCHAR},fuc_effective =
      #{effective,jdbcType=BOOLEAN},fuc_create_time =
      #{createTime,jdbcType=TIMESTAMP},fuc_update_time =
      #{updateTime,jdbcType=TIMESTAMP},fuc_beizhu=
      #{beiZhu,jdbcType=VARCHAR}
       where fuc_id = #{id,jdbcType=BIGINT}
   </update>
   <update id="updateByPrimaryKeySelective"
      parameterType="com.yeshi.fanli.entity.bus.user.ForbiddenUserIdentifyCode">
      update yeshi_ec_forbidden_user_identify_code
      <set>
         <if test="type != null">fuc_type=#{type,jdbcType=VARCHAR},</if>
         <if test="identifyCode != null">fuc_identify_code=#{identifyCode,jdbcType=VARCHAR},</if>
         <if test="effective != null">fuc_effective=#{effective,jdbcType=BOOLEAN},</if>
         <if test="createTime != null">fuc_create_time=#{createTime,jdbcType=TIMESTAMP},</if>
         <if test="updateTime != null">fuc_update_time=#{updateTime,jdbcType=TIMESTAMP},</if>
         <if test="beiZhu != null">fuc_beizhu=#{beiZhu,jdbcType=VARCHAR},</if>
      </set>
      where fuc_id = #{id,jdbcType=BIGINT}
   </update>
   <select id="listQuery" resultMap="BaseResultMapVO">
      SELECT * FROM (SELECT A.uid,A.alipayAccount,A.alipayAccountName,MAX(A.f_wxUnionId) AS f_wxUnionId ,MAX(A.f_taobaoUid) AS f_taobaoUid,MAX(A.f_phone) AS f_phone,MAX(A.f_alipayAccount) AS f_alipayAccount FROM
      (SELECT u.`id`AS uid,b.account AS alipayAccount,b.name AS alipayAccountName,fu.* FROM yeshi_ec_user u
      LEFT JOIN yeshi_ec_binding_account b ON b.`uid` = u.`id`
      LEFT JOIN (SELECT fc.fuc_effective,IF(fc.`fuc_type` = 'wxUnionId',fc.`fuc_identify_code`,NULL)AS f_wxUnionId,
         IF(fc.`fuc_type` = 'taobaoUid',fc.`fuc_identify_code`,NULL)AS f_taobaoUid,
         IF(fc.`fuc_type` = 'phone',fc.`fuc_identify_code`,NULL)AS f_phone,
         IF(fc.`fuc_type` = 'alipayAccount',fc.`fuc_identify_code`,NULL)AS f_alipayAccount
      FROM yeshi_ec_forbidden_user_identify_code fc)fu ON (fu.f_wxUnionId = u.`wx_union_id` OR fu.f_taobaoUid = u.`identifycode` OR fu.f_phone = u.`phone` OR fu.f_alipayAccount = b.`account`)
      WHERE b.`type`= 1 AND fu.fuc_effective = 1
         <if test="key != null and key != '' ">
            AND fu.fuc_identify_code = '%#{key}%'
         </if>
         <if test="type == 1">
            AND fu.fuc_type = 'wxUnionId'
         </if>
         <if test="type == 2">
            AND fu.fuc_type = 'taobaoUid'
         </if>
         <if test="type == 3">
            AND fu.fuc_type = 'phone'
         </if>
         <if test="type == 4">
            AND fu.fuc_type = 'alipayAccount'
         </if>
      )A
      GROUP BY A.uid) B
      LEFT JOIN yeshi_ec_user u ON u.id= B.uid
      LIMIT ${start},${count}
   </select>
   <select id="countQuery" resultType="java.lang.Long">
      SELECT IFNULL(COUNT(DISTINCT A.uid),0) FROM
      (SELECT u.`id`AS uid,fu.* FROM yeshi_ec_user u
      LEFT JOIN yeshi_ec_binding_account b ON b.`uid` = u.`id`
      LEFT JOIN (SELECT fc.fuc_effective,IF(fc.`fuc_type` = 'wxUnionId',fc.`fuc_identify_code`,NULL)AS f_wxUnionId,
         IF(fc.`fuc_type` = 'taobaoUid',fc.`fuc_identify_code`,NULL)AS f_taobaoUid,
         IF(fc.`fuc_type` = 'phone',fc.`fuc_identify_code`,NULL)AS f_phone,
         IF(fc.`fuc_type` = 'alipayAccount',fc.`fuc_identify_code`,NULL)AS f_alipayAccount
      FROM yeshi_ec_forbidden_user_identify_code fc)fu ON (fu.f_wxUnionId = u.`wx_union_id` OR fu.f_taobaoUid = u.`identifycode` OR fu.f_phone = u.`phone` OR fu.f_alipayAccount = b.`account`)
      WHERE b.`type`= 1 AND fu.fuc_effective = 1
         <if test="key != null and key != '' ">
            AND fu.fuc_identify_code = '%#{key}%'
         </if>
         <if test="type == 1">
            AND fu.fuc_type = 'wxUnionId'
         </if>
         <if test="type == 2">
            AND fu.fuc_type = 'taobaoUid'
         </if>
         <if test="type == 3">
            AND fu.fuc_type = 'phone'
         </if>
         <if test="type == 4">
            AND fu.fuc_type = 'alipayAccount'
         </if>
      )A
   </select>
</mapper>
<?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.yeshi.fanli.dao.mybatis.user.ForbiddenUserIdentifyCodeMapper">
   <resultMap id="BaseResultMap"
      type="com.yeshi.fanli.entity.bus.user.ForbiddenUserIdentifyCode">
      <id column="fuc_id" property="id" jdbcType="BIGINT" />
      <result column="fuc_type" property="type"
         typeHandler="com.yeshi.fanli.util.mybatishandler.ForbiddenUserIdentifyCodeTypeEnumHandler" />
      <result column="fuc_uid" property="user" jdbcType="VARCHAR" />
      <result column="fuc_identify_code" property="identifyCode"
         jdbcType="VARCHAR" />
      <result column="fuc_effective" property="effective" jdbcType="BOOLEAN" />
      <result column="fuc_create_time" property="createTime"
         jdbcType="TIMESTAMP" />
      <result column="fuc_update_time" property="updateTime"
         jdbcType="TIMESTAMP" />
   </resultMap>
   <sql id="Base_Column_List">fuc_id,fuc_type,fuc_identify_code,fuc_effective,fuc_create_time,fuc_update_time,fuc_beizhu
   </sql>
   <select id="selectByPrimaryKey" resultMap="BaseResultMap"
      parameterType="java.lang.Long">
      select
      <include refid="Base_Column_List" />
      from yeshi_ec_forbidden_user_identify_code where fuc_id =
      #{id,jdbcType=BIGINT}
   </select>
   <select id="listByTypeAndIdentifyCode" resultMap="BaseResultMap">
      select
      <include refid="Base_Column_List" />
      from yeshi_ec_forbidden_user_identify_code where fuc_type =
      #{type} and
      fuc_identify_code=#{identifyCode}
   </select>
   <delete id="deleteByPrimaryKey" parameterType="java.lang.Long">delete from
      yeshi_ec_forbidden_user_identify_code where fuc_id =
      #{id,jdbcType=BIGINT}
   </delete>
   <insert id="insert"
      parameterType="com.yeshi.fanli.entity.bus.user.ForbiddenUserIdentifyCode"
      useGeneratedKeys="true" keyProperty="id">insert into
      yeshi_ec_forbidden_user_identify_code
      (fuc_id,fuc_type,fuc_identify_code,fuc_effective,fuc_create_time,fuc_update_time,fuc_beizhu)
      values
      (#{id,jdbcType=BIGINT},#{type,jdbcType=VARCHAR},#{identifyCode,jdbcType=VARCHAR},#{effective,jdbcType=BOOLEAN},#{createTime,jdbcType=TIMESTAMP},#{updateTime,jdbcType=TIMESTAMP},#{beiZhu,jdbcType=VARCHAR})
   </insert>
   <insert id="insertSelective"
      parameterType="com.yeshi.fanli.entity.bus.user.ForbiddenUserIdentifyCode"
      useGeneratedKeys="true" keyProperty="id">
      insert into yeshi_ec_forbidden_user_identify_code
      <trim prefix="(" suffix=")" suffixOverrides=",">
         <if test="id != null">fuc_id,</if>
         <if test="type != null">fuc_type,</if>
         <if test="identifyCode != null">fuc_identify_code,</if>
         <if test="effective != null">fuc_effective,</if>
         <if test="createTime != null">fuc_create_time,</if>
         <if test="updateTime != null">fuc_update_time,</if>
         <if test="beiZhu != null">fuc_beizhu,</if>
      </trim>
      values
      <trim prefix="(" suffix=")" suffixOverrides=",">
         <if test="id != null">#{id,jdbcType=BIGINT},</if>
         <if test="type != null">#{type,jdbcType=VARCHAR},</if>
         <if test="identifyCode != null">#{identifyCode,jdbcType=VARCHAR},</if>
         <if test="effective != null">#{effective,jdbcType=BOOLEAN},</if>
         <if test="createTime != null">#{createTime,jdbcType=TIMESTAMP},</if>
         <if test="updateTime != null">#{updateTime,jdbcType=TIMESTAMP},</if>
         <if test="beiZhu != null">#{beiZhu,jdbcType=VARCHAR},</if>
      </trim>
   </insert>
   <update id="updateByPrimaryKey"
      parameterType="com.yeshi.fanli.entity.bus.user.ForbiddenUserIdentifyCode">update yeshi_ec_forbidden_user_identify_code set
      fuc_type = #{type,jdbcType=VARCHAR},fuc_identify_code =
      #{identifyCode,jdbcType=VARCHAR},fuc_effective =
      #{effective,jdbcType=BOOLEAN},fuc_create_time =
      #{createTime,jdbcType=TIMESTAMP},fuc_update_time =
      #{updateTime,jdbcType=TIMESTAMP},fuc_beizhu=
      #{beiZhu,jdbcType=VARCHAR}
       where fuc_id = #{id,jdbcType=BIGINT}
   </update>
   <update id="updateByPrimaryKeySelective"
      parameterType="com.yeshi.fanli.entity.bus.user.ForbiddenUserIdentifyCode">
      update yeshi_ec_forbidden_user_identify_code
      <set>
         <if test="type != null">fuc_type=#{type,jdbcType=VARCHAR},</if>
         <if test="identifyCode != null">fuc_identify_code=#{identifyCode,jdbcType=VARCHAR},</if>
         <if test="effective != null">fuc_effective=#{effective,jdbcType=BOOLEAN},</if>
         <if test="createTime != null">fuc_create_time=#{createTime,jdbcType=TIMESTAMP},</if>
         <if test="updateTime != null">fuc_update_time=#{updateTime,jdbcType=TIMESTAMP},</if>
         <if test="beiZhu != null">fuc_beizhu=#{beiZhu,jdbcType=VARCHAR},</if>
      </set>
      where fuc_id = #{id,jdbcType=BIGINT}
   </update>
</mapper>