Blame view

CourseDictMapper.xml 4.75 KB
涂亚平 committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
<?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.CourseDictMapper">

    <!-- 通用查询映射结果 -->
    <resultMap id="BaseResultMap" type="com.subsidy.model.CourseDictDO">
        <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="course_name" property="courseName" />
        <result column="course_type" property="courseType" />
    </resultMap>

    <!-- 通用查询结果列 -->
涂亚平 committed
16 17
    <select id="queryCourses" resultType="com.subsidy.vo.course.QueryCoursesVO">
        SELECT
涂亚平 committed
18
        distinct
涂亚平 committed
19 20 21
            t.id,
            t.course_name,
            t.course_type,
涂亚平 committed
22
            t.open_status,
涂亚平 committed
23 24
            t.cover_page,
            t.remark
涂亚平 committed
25
        FROM
涂亚平 committed
26 27 28 29 30
            course_dict t
        LEFT JOIN course_field_mapping t2 ON t.id = t2.course_id
        LEFT JOIN course_category_mapping t3 ON t.id = t3.course_id
        LEFT JOIN course_job_mapping t4 ON t.id = t4.course_id
        left join course_rank_mapping t5 on t.id = t5.course_id
涂亚平 committed
31
        WHERE
涂亚平 committed
32 33 34 35 36 37 38
            t.delete_date IS NULL
        AND t2.delete_date IS NULL
        AND t3.delete_date IS NULL
        AND t4.delete_date IS NULL
        and t5.delete_date is null
        <if test="companyId != null and companyId != ''">
            and t.company_id = #{companyId}
涂亚平 committed
39
        </if>
涂亚平 committed
40
        <if test="companyId == null">
涂亚平 committed
41 42
            and t.company_id is null
        </if>
涂亚平 committed
43 44 45 46 47 48
        <if test="courseName != null and courseName !=''">
            AND t.course_name like concat('%',#{courseName} ,'%')
        </if>
        <if test="courseType != null and courseType !=''">
            AND t.course_type = #{courseType}
        </if>
涂亚平 committed
49 50 51 52 53 54 55
        <if test="jobId != null and jobId != ''">
            and t4.job_id = #{jobId}
        </if>
        <if test="categoryId != null and categoryId != ''">
            and t3.category_id = #{categoryId}
        </if>
        <if test="fieldId != null and fieldId != ''">
涂亚平 committed
56
            and t2.field_id = #{fieldId}
涂亚平 committed
57 58 59 60
        </if>
        <if test="rankId != null and rankId != ''">
            and t5.rank_id = #{rankId}
        </if>
涂亚平 committed
61 62 63
        <if test="openStatus != null and openStatus != ''">
            and t.open_status = #{openStatus}
        </if>
涂亚平 committed
64 65
    </select>

涂亚平 committed
66 67 68 69 70 71 72
    <sql id="Base_Column_List">
        create_date,
        update_date,
        delete_date,
        id, course_name, category_id, course_type, course_source
    </sql>

涂亚平 committed
73
    <select id="queryCourseMember" parameterType="com.subsidy.vo.member.StudyPageVO" resultType="com.subsidy.model.ClassMemberMappingDO">
涂亚平 committed
74
        SELECT
涂亚平 committed
75
            t3.*
涂亚平 committed
76 77
        FROM
            course_dict t
涂亚平 committed
78 79
            LEFT JOIN class_dict t2 ON t.id = t2.course_id
            LEFT JOIN class_member_mapping t3 ON t2.id = t3.member_id
涂亚平 committed
80 81
        WHERE
            t.delete_date IS NULL
涂亚平 committed
82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
            AND t2.delete_date IS NULL
            AND t3.delete_date IS NULL
            AND t.id = {classId}
    </select>

    <select id="queryPublicCourses" resultType="com.subsidy.vo.course.QueryCoursesVO">
        SELECT
        t.*,
        t2.name
        FROM
        course_dict t
        left join category t2 on t.category_id = t2.id
        WHERE
        t.delete_date IS NULL
        <if test="categoryId != null">
涂亚平 committed
97
            AND t.category_id = #{categoryId}
涂亚平 committed
98 99
        </if>
        <if test="courseName != null and courseName !=''">
涂亚平 committed
100
            AND t.course_name like concat('%',#{courseName} ,'%')
涂亚平 committed
101 102 103 104 105
        </if>
        <if test="courseSource != null and courseSource != ''">
            AND t.course_source = #{courseSource}
        </if>
        <if test="courseType != null and courseType !=''">
涂亚平 committed
106
            AND t.course_type = #{courseType}
涂亚平 committed
107 108
        </if>
            AND t.administer_id is null
涂亚平 committed
109 110
    </select>

涂亚平 committed
111
    <select id="queryCourseCnt" parameterType="long" resultType="integer">
涂亚平 committed
112
        SELECT
涂亚平 committed
113
            count( t2.id )
涂亚平 committed
114
        FROM
涂亚平 committed
115 116
            course_content t1
            LEFT JOIN vod_dict t2 ON t1.id = t2.content_id
涂亚平 committed
117
        WHERE
涂亚平 committed
118 119 120
            t1.delete_date IS NULL
            AND t2.delete_date IS NULL
            AND t1.course_id = #{courseId}
涂亚平 committed
121
    </select>
122

涂亚平 committed
123 124 125 126 127 128 129 130 131 132 133
    <select id="queryCoursePlayLength" parameterType="long" resultType="integer">
        SELECT
            sum( t2.vod_length )
        FROM
            course_content t1
            LEFT JOIN vod_dict t2 ON t1.id = t2.content_id
        WHERE
            t1.delete_date IS NULL
            AND t2.delete_date IS NULL
            AND t1.course_id = #{courseId}
    </select>
134

涂亚平 committed
135 136 137
    <update id="updateOpenStatus">
        update course_dict set open_status = #{openStatus} where id = #{id}
    </update>
138

涂亚平 committed
139
</mapper>