BigdataSimilarSknMapper.xml 3.42 KB
<?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.yoho.search.dal.BigdataSimilarSknMapper">

    <resultMap id="BaseResultMap" type="com.yoho.search.dal.model.BigdataSimilarSkn">
        <id column="product_skn" property="productSkn" jdbcType="INTEGER"/>
        <result column="date_id" property="dataId" jdbcType="INTEGER"/>
        <result column="same_shop_action_similar_skns" property="sameShopActionSimilarSkns" jdbcType="VARCHAR"/>
        <result column="diff_shop_action_similar_skns" property="diffShopActionSimilarSkns" jdbcType="VARCHAR"/>
        <result column="same_shop_img_similar_skns" property="sameShopImgSimilarSkns" jdbcType="VARCHAR"/>
        <result column="diff_shop_img_similar_skns" property="diffShopImgSimilarSkns" jdbcType="VARCHAR"/>
        <result column="same_shop_collocation_skns" property="sameShopCollocationSkns" jdbcType="VARCHAR"/>
        <result column="diff_shop_collocation_skns" property="diffShopCollocationSkns" jdbcType="VARCHAR"/>
        <result column="create_time" property="createTime" jdbcType="INTEGER"/>
    </resultMap>

    <resultMap id="MonitorResultMap" type="com.yoho.search.dal.model.BigdataMonitor">
        <result column="date_id" property="dateId" jdbcType="INTEGER"/>
        <result column="num" property="num" jdbcType="INTEGER"/>
    </resultMap>

    <sql id="Base_Column_List">
        product_skn, date_id, same_shop_action_similar_skns, diff_shop_action_similar_skns, same_shop_img_similar_skns, diff_shop_img_similar_skns, same_shop_collocation_skns, diff_shop_collocation_skns, create_time
    </sql>

    <select id="selectLatestDateId" resultType="java.lang.Integer">
        select max(date_id) from bigdata_similar_skn limit 1
    </select>

    <select id="selectCount" resultType="java.lang.Integer" timeout="20000">
        SELECT count(*) FROM bigdata_similar_skn where date_id=#{dateId}
    </select>

    <select id="selectPageLists" resultMap="BaseResultMap" timeout="20000">
        select
        <include refid="Base_Column_List"/>
        from bigdata_similar_skn where date_id=#{dateId} limit #{offset},#{pageSize}
    </select>

    <select id="selectBySknList" resultMap="BaseResultMap" timeout="20000">
        select
        <include refid="Base_Column_List"/>
        from bigdata_similar_skn
        WHERE
        date_id = #{dateId,jdbcType=VARCHAR}
        AND
        product_skn in
        <foreach item="item" index="index" collection="sknList" open="(" separator="," close=")">
            #{item}
        </foreach>
    </select>

    <select id="selectSknByDate" resultType="java.lang.Long" timeout="20000">
        SELECT product_skn FROM bigdata_similar_skn where date_id = #{dateId,jdbcType=VARCHAR} limit #{pageSize}
    </select>

    <delete id="deleteBatch">
        DELETE FROM bigdata_similar_skn
        WHERE
        date_id = #{dateId,jdbcType=VARCHAR}
        AND
        product_skn in
        <foreach item="item" index="index" collection="sknList" open="(" separator="," close=")">
            #{item}
        </foreach>
    </delete>


    <select id="selectCountGroupByDateId" resultMap="MonitorResultMap">
        SELECT date_id, count(*) num FROM bigdata_similar_skn where date_id in (#{yesterday}, #{beforYesterday}) GROUP BY date_id ORDER BY date_id desc
    </select>

</mapper>