ClassDictMapper.xml 9.09 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.subsidy.mapper.ClassDictMapper">

    <!-- 通用查询映射结果 -->
    <resultMap id="BaseResultMap" type="com.subsidy.model.ClassDictDO">
        <id column="id" property="id"/>
        <result column="create_date" property="createDate"/>
        <result column="update_date" property="updateDate"/>
        <result column="delete_date" property="deleteDate"/>
        <result column="class_name" property="className"/>
        <result column="course_id" property="courseId"/>
        <result column="start_date" property="startDate"/>
        <result column="end_date" property="endDate"/>
    </resultMap>

    <!-- 通用查询结果列 -->
    <sql id="Base_Column_List">
        create_date,
        update_date,
        delete_date,
        id, class_name, course_id, start_date, end_date
    </sql>

    <select id="getAllClasses" resultType="com.subsidy.vo.classdict.GetAllClassesVO">
        SELECT
        t.id,
        t2.id as courseId,
        t.class_name,
        t2.course_name,
        t.start_date,
        t.end_date,
        t4.cnt,
        t5.class_type,
        t5.id as class_type_id,
        t.class_code
        FROM
        class_dict t
        left join class_type_dict t5 on t.class_type_id = t5.id
        LEFT JOIN course_dict t2 ON t.course_id = t2.id
        LEFT JOIN ( SELECT t3.class_id, sum( 1 ) AS cnt FROM class_member_mapping t3 WHERE t3.delete_date IS NULL GROUP
        BY t3.class_id ) t4 ON t.id = t4.class_id
        WHERE
        t.delete_date IS NULL
        AND t2.delete_date IS NULL
        and t5.delete_date is null
        and t.company_id = #{companyId}
        <if test="className != null and className !=''">
            and t.class_name like concat('%',#{className} ,'%')
        </if>
        <if test="startDate != null and endDate != null and startDate != '' and endDate != ''">
            and t.end_date >= DATE_FORMAT( #{startDate}, '%Y-%m-%d' )
            and t.start_date  &lt; DATE_FORMAT( #{endDate}, '%Y-%m-%d' )
        </if>
        order by t.create_date desc
    </select>

    <select id="getClassVods" parameterType="long" resultType="com.subsidy.model.VodDictDO">
        SELECT
            t3.*
        FROM
            class_dict t
            LEFT JOIN course_content t2 ON t.course_id = t2.course_id
            LEFT JOIN content_vod_mapping t4 ON t4.content_id = t2.id
            LEFT JOIN vod_dict t3 ON t3.id = t4.vod_id
        WHERE
            t.delete_date IS NULL
            AND t2.delete_date IS NULL
            AND t3.delete_date IS NULL
            AND t4.delete_date IS NULL
            AND t3.id IS NOT NULL
            AND t.id = #{classId}
    </select>

    <select id="getSpareMembers" parameterType="com.subsidy.dto.classDict.GetSpareMembersDTO"
            resultType="com.subsidy.model.MemberDO">
       SELECT
           distinct 	t2.id,
                        t2.company_id,
                        t2.user_name,
                        t2.account_name,
                        t2.telephone,
                        t2.PASSWORD,
                        t2.gender,
                        t2.image,
                        t2.id_card,
                        t2.STATUS,
                        t2.first_login
        FROM
            member t2
	    LEFT JOIN member_department_mapping t ON t.member_id = t2.id
	    left join department_dict t3 on t.department_id = t3.id
	    left join company_dict t4 on t3.company_id = t4.id
        WHERE
            t.delete_date IS NULL
            AND t2.delete_date IS NULL
            AND t3.company_id = #{companyId}
            AND t2.id NOT IN (
            SELECT
                t3.member_id
            FROM
                class_member_mapping t3
            WHERE
            t3.delete_date IS NULL
            AND t3.class_id = #{classId})
             <if test="userName != null and userName !=''">
                and t2.user_name like concat('%',#{userName} ,'%')
            </if>
    </select>

    <select id="classMembers" parameterType="long" resultType="com.subsidy.model.MemberDO">
        SELECT
            	t2.id,
                t2.company_id,
                t2.user_name,
                t2.account_name,
                t2.telephone,
                t2.PASSWORD,
                t2.gender,
                t2.image,
                t2.id_card,
                t2.STATUS,
                t2.first_login
        FROM
            class_member_mapping t
            LEFT JOIN member t2 ON t.member_id = t2.id
        WHERE
            t.delete_date IS NULL
            AND t2.delete_date IS NULL
            AND t.class_id = #{classId}
    </select>

    <select id="getClassBaseInfo" parameterType="long" resultType="com.subsidy.vo.classdict.GetClassBaseInfoVO">
        SELECT
            t3.class_type,
            t.class_name,
            t2.course_name,
            t.start_date,
            t.end_date,
            ifnull( t4.cnt, 0 ) AS count,
            t2.id as courseId,
            t3.id as classTypeId,
            t.is_order,
            t.is_fast_play,
            t.test_rule,
            t2.cover_page,
            t.class_code
        FROM
            class_dict t
            LEFT JOIN course_dict t2 ON t.course_id = t2.id
            LEFT JOIN class_type_dict t3 ON t.class_type_id = t3.id
            LEFT JOIN ( SELECT t.class_id, count( 1 ) AS cnt FROM class_member_mapping t WHERE t.delete_date IS NULL AND t.class_id = #{classId} ) t4 ON t.id = t4.class_id
        WHERE
            t.delete_date IS NULL
            AND t2.delete_date IS NULL
            AND t3.delete_date IS NULL
            AND t.id = #{classId}
    </select>

    <select id="getClassAndCompanyInfoVO" resultType="com.subsidy.vo.classdict.ClassAndCompanyInfoVO">
        SELECT
            cd.company_name AS company,
            cd.short_name AS NAME,
            d.course_name,
            c.start_date,
            c.end_date
        FROM
            class_dict c
            LEFT JOIN company_dict cd ON cd.id = c.company_id
            LEFT JOIN course_dict d ON d.id = c.course_id
        WHERE
            c.id = #{classId}
            AND c.delete_date IS NULL
            AND cd.delete_date IS NULL
            AND d.delete_date IS NULL
    </select>

    <select id="getClassCount" resultType="java.lang.Integer">
        SELECT
            count(t1.id)
        FROM
            class_dict t1
            LEFT JOIN course_dict t2 ON t2.id = t1.course_id
        WHERE
            t2.course_type = "补贴培训"
          AND t1.delete_date IS NULL
          AND t2.delete_date IS NULL
    </select>

    <select id="getClassSettings" resultType="com.subsidy.vo.classdict.ClassSettingsVO">
        SELECT
            t1.*,
            t3.ip_address_record,
            t3.device_no_record
        FROM
            class_dict t1
            LEFT JOIN class_member_mapping t2 ON t2.class_id = t1.id
            LEFT JOIN company_dict t3 ON t3.id = t1.company_id
        WHERE
            t2.member_id = #{userId}
          AND t1.delete_date IS NULL
          AND t2.delete_date IS NULL
          AND t3.delete_date IS NULL
    </select>

    <select id="getCompanySettings" parameterType="long" resultType="com.subsidy.vo.classdict.SystemSettings">
        SELECT
            t2.id,
            t2.time_limit,
            t2.ip_address_record,
            t2.device_no_record
        FROM
            class_dict t
            LEFT JOIN company_dict t2 ON t.company_id = t2.id
        WHERE
            t.delete_date IS NULL
            AND t2.delete_date IS NULL
            AND t.id = #{classId}
    </select>

    <select id="getAllCertClasses" resultType="com.subsidy.vo.classdict.GetAllClassesVO">
        SELECT
        t.id,
        t2.id as courseId,
        t.class_name,
        t2.course_name,
        t.start_date,
        t.end_date,
        t4.cnt,
        t5.class_type,
        t5.id as class_type_id
        FROM
        class_dict t
        left join class_type_dict t5 on t.class_type_id = t5.id
        LEFT JOIN course_dict t2 ON t.course_id = t2.id
        LEFT JOIN ( SELECT t3.class_id, sum( 1 ) AS cnt FROM class_member_mapping t3 WHERE t3.delete_date IS NULL GROUP
        BY t3.class_id ) t4 ON t.id = t4.class_id
        WHERE
        t.delete_date IS NULL
        AND t2.delete_date IS NULL
        and t5.delete_date is null
        and t5.id = 0
        <if test="className != null and className !=''">
            and t.class_name like concat('%',#{className} ,'%')
        </if>
        <if test="startDate != null and endDate != null and startDate != '' and endDate != ''">
            and t.end_date >= DATE_FORMAT( #{startDate}, '%Y-%m-%d' )
            and t.start_date  &lt; DATE_FORMAT( #{endDate}, '%Y-%m-%d' )
        </if>
        order by t.create_date desc
    </select>

    <select id="dailyClassInfo" resultType="long">
        SELECT DISTINCT
            t1.class_id
        FROM
            vod_play_history t1
        WHERE
            DATE_FORMAT( DATE_ADD( t1.create_date, INTERVAL 1 DAY ), '%Y-%m-%d' ) = DATE_FORMAT( NOW(), '%Y-%m-%d' )
            AND t1.delete_date IS NULL
    </select>

</mapper>