| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 | <?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.fs.course.mapper.FsCourseAnswerLogsMapper">    <resultMap type="FsCourseAnswerLogs" id="FsCourseAnswerLogsResult">        <result property="logId"    column="log_id"    />        <result property="userId"    column="user_id"    />        <result property="videoId"    column="video_id"    />        <result property="isRight"    column="is_right"    />        <result property="createTime"    column="create_time"    />        <result property="companyId"    column="company_id"    />        <result property="companyUserId"    column="company_user_id"    />        <result property="qwUserId"    column="qw_user_id"    />        <result property="courseId"    column="course_id"    />        <result property="answer"    column="answer"    />        <result property="questionId"    column="question_id"    />        <result property="questionJson"    column="question_json"    />        <result property="periodId"    column="period_id"    />    </resultMap>    <sql id="selectFsCourseAnswerLogsVo">        select * from fs_course_answer_logs    </sql>    <select id="selectFsCourseAnswerLogsList" parameterType="FsCourseAnswerLogs" resultMap="FsCourseAnswerLogsResult">        <include refid="selectFsCourseAnswerLogsVo"/>        <where>            <if test="userId != null "> and user_id = #{userId}</if>            <if test="videoId != null "> and video_id = #{videoId}</if>            <if test="isRight != null "> and is_right = #{isRight}</if>            <if test="companyUserId != null "> and company_user_id = #{companyUserId}</if>            <if test="companyId != null "> and company_id = #{companyId}</if>            <if test="qwUserId != null "> and qw_user_id = #{qwUserId}</if>        </where>    </select>    <select id="selectFsCourseAnswerLogsByLogId" parameterType="Long" resultMap="FsCourseAnswerLogsResult">        <include refid="selectFsCourseAnswerLogsVo"/>        where log_id = #{logId}    </select>    <insert id="insertFsCourseAnswerLogs" parameterType="FsCourseAnswerLogs" useGeneratedKeys="true" keyProperty="logId">        insert into fs_course_answer_logs        <trim prefix="(" suffix=")" suffixOverrides=",">            <if test="userId != null">user_id,</if>            <if test="videoId != null">video_id,</if>            <if test="isRight != null">is_right,</if>            <if test="createTime != null">create_time,</if>            <if test="companyId != null">company_id,</if>            <if test="companyUserId != null">company_user_id,</if>            <if test="qwUserId != null">qw_user_id,</if>            <if test="courseId != null">course_id,</if>            <if test="questionJson != null">question_json,</if>            <if test="watchLogId != null">watch_log_id,</if>            <if test="periodId != null">period_id,</if>        </trim>        <trim prefix="values (" suffix=")" suffixOverrides=",">            <if test="userId != null">#{userId},</if>            <if test="videoId != null">#{videoId},</if>            <if test="isRight != null">#{isRight},</if>            <if test="createTime != null">#{createTime},</if>            <if test="companyId != null">#{companyId},</if>            <if test="companyUserId != null">#{companyUserId},</if>            <if test="qwUserId != null">#{qwUserId},</if>            <if test="courseId != null">#{courseId},</if>            <if test="questionJson != null">#{questionJson},</if>            <if test="watchLogId != null">#{watchLogId},</if>            <if test="periodId != null">#{periodId},</if>        </trim>    </insert>    <update id="updateFsCourseAnswerLogs" parameterType="FsCourseAnswerLogs">        update fs_course_answer_logs        <trim prefix="SET" suffixOverrides=",">            <if test="userId != null">user_id = #{userId},</if>            <if test="videoId != null">video_id = #{videoId},</if>            <if test="isRight != null">is_right = #{isRight},</if>            <if test="createTime != null">create_time = #{createTime},</if>            <if test="companyId != null">company_id = #{companyId},</if>            <if test="companyUserId != null">company_user_id = #{companyUserId},</if>            <if test="qwUserId != null">qw_user_id = #{qwUserId},</if>            <if test="courseId != null">course_id = #{courseId},</if>            <if test="watchLogId != null">watch_log_id = #{watchLogId},</if>            <if test="periodId != null">period_id = #{periodId},</if>        </trim>        where log_id = #{logId}    </update>    <delete id="deleteFsCourseAnswerLogsByLogId" parameterType="Long">        delete from fs_course_answer_logs where log_id = #{logId}    </delete>    <delete id="deleteFsCourseAnswerLogsByLogIds" parameterType="String">        delete from fs_course_answer_logs where log_id in        <foreach item="logId" collection="array" open="(" separator="," close=")">            #{logId}        </foreach>    </delete>    <select id="selectFsCourseAnswerLogsListVONew" resultType="com.fs.course.vo.FsCourseAnswerLogsListVO">        SELECT        cal.*, uc.course_name AS course_name, uc.project AS project        FROM        fs_course_answer_logs cal        INNER JOIN (        SELECT        cal_inner.log_id        FROM        fs_course_answer_logs cal_inner        LEFT JOIN fs_user_course uc_inner ON cal_inner.course_id = uc_inner.course_id        <where>            <if test="courseId != null">                cal_inner.course_id = #{courseId}            </if>            <if test="videoId != null and videoId != '' ">                AND cal_inner.video_id = #{videoId}            </if>            <if test="companyUserId != null">                AND cal_inner.company_user_id = #{companyUserId}            </if>            <if test="companyId != null">                AND cal_inner.company_id = #{companyId}            </if>            <if test="isRight != null">                AND cal_inner.is_right = #{isRight}            </if>            <if test="project != null">                AND uc_inner.project = #{project}            </if>            <if test="sTime != null and eTime != null">                AND cal_inner.create_time BETWEEN #{sTime} AND #{eTime}            </if>            <if test="userIds != null and userIds.size() > 0">                and cal_inner.user_id in                <foreach collection="userIds"  open="(" close=")" separator="," item="userId" index="index">                    #{userId}                </foreach>            </if>            <if test="watchLogId != null">                AND cal_inner.watch_log_id = #{watchLogId}            </if>        </where>        ORDER BY cal_inner.log_id DESC        LIMIT ${(pageNum-1)*pageSize}, ${pageSize}        ) AS paged_ids ON cal.log_id = paged_ids.log_id        LEFT JOIN fs_user_course uc ON cal.course_id = uc.course_id        ORDER BY        cal.log_id DESC    </select>    <select id="selectFsCourseAnswerLogsListVONewCount" resultType="java.lang.Long">        SELECT        count(1)        FROM        fs_course_answer_logs cal        INNER JOIN (        SELECT        cal_inner.log_id        FROM        fs_course_answer_logs cal_inner        LEFT JOIN fs_user_course uc_inner ON cal_inner.course_id = uc_inner.course_id        <where>            <if test="courseId != null">                cal_inner.course_id = #{courseId}            </if>            <if test="videoId != null and videoId != '' ">                AND cal_inner.video_id = #{videoId}            </if>            <if test="companyUserId != null">                AND cal_inner.company_user_id = #{companyUserId}            </if>            <if test="companyId != null">                AND cal_inner.company_id = #{companyId}            </if>            <if test="isRight != null">                AND cal_inner.is_right = #{isRight}            </if>            <if test="project != null">                AND uc_inner.project = #{project}            </if>            <if test="sTime != null and eTime != null">                AND cal_inner.create_time BETWEEN #{sTime} AND #{eTime}            </if>            <if test="userIds != null and userIds.size() > 0">                and cal_inner.user_id in                <foreach collection="userIds"  open="(" close=")" separator="," item="userId" index="index">                    #{userId}                </foreach>            </if>            <if test="watchLogId != null">                AND cal_inner.watch_log_id = #{watchLogId}            </if>        </where>        ) AS paged_ids ON cal.log_id = paged_ids.log_id    </select>        <select id="selectRedStatus" resultType="java.lang.Long">        select count(log_id)        from fs_course_red_packet_log        where user_id = #{userId} and video_id = #{videoId}        <if test="periodId != null">            and period_id = #{periodId}        </if>    </select></mapper>
 |