Blame view

ClassDictMapper.xml 3.4 KB
涂亚平 committed
1 2 3 4 5 6
<?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">
涂亚平 committed
7 8 9 10 11 12 13 14
        <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"/>
涂亚平 committed
15 16 17 18 19 20 21 22 23 24 25 26
    </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
涂亚平 committed
27 28 29 30 31 32
        t.id,
        t2.id as courseId,
        t.class_name,
        t2.course_name,
        t.start_date,
        t.end_date,
33 34
        t4.cnt,
        t.class_type
涂亚平 committed
35 36 37 38 39 40 41 42 43 44 45 46
        FROM
        class_dict t
        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 t.company_id = #{companyId}
        <if test="className != null and className !=''">
            and t.class_name like concat('%',#{className} ,'%')
        </if>
涂亚平 committed
47
        order by t.create_date desc
涂亚平 committed
48 49 50 51 52
    </select>

    <select id="getClassVods" parameterType="long" resultType="com.subsidy.model.VodDictDO">
        SELECT
            t3.*
涂亚平 committed
53 54
        FROM
            class_dict t
涂亚平 committed
55 56
            LEFT JOIN course_content t2 ON t.course_id = t2.course_id
            LEFT JOIN vod_dict t3 ON t2.id = t3.content_id
涂亚平 committed
57 58 59
        WHERE
            t.delete_date IS NULL
            AND t2.delete_date IS NULL
涂亚平 committed
60 61 62 63 64 65 66 67
            AND t3.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
涂亚平 committed
68
           distinct t2.*
涂亚平 committed
69 70
        FROM
            member t2
涂亚平 committed
71 72 73
	    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
涂亚平 committed
74 75 76
        WHERE
            t.delete_date IS NULL
            AND t2.delete_date IS NULL
涂亚平 committed
77
            AND t3.company_id = #{companyId}
涂亚平 committed
78 79
            AND t2.id NOT IN (
            SELECT
80
                t3.member_id
涂亚平 committed
81 82 83 84 85
            FROM
                class_member_mapping t3
            WHERE
            t3.delete_date IS NULL
            AND t3.class_id = #{classId})
涂亚平 committed
86 87
    </select>

88 89 90 91 92 93 94 95 96 97 98 99
    <select id="classMembers" parameterType="long" resultType="com.subsidy.model.MemberDO">
        SELECT
            t2.*
        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>

涂亚平 committed
100
</mapper>