Blame view

CourseDictMapper.xml 5.76 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
            t.cover_page,
涂亚平 committed
24 25
            t.remark,
            t.course_data_type
涂亚平 committed
26
        FROM
涂亚平 committed
27 28 29 30 31
            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
32
        left join course_business_mapping t6 on t.id = t6.course_id
涂亚平 committed
33
        WHERE
涂亚平 committed
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
涂亚平 committed
39
        and t6.delete_date is null
涂亚平 committed
40 41
        <if test="companyId != null and companyId != ''">
            and t.company_id = #{companyId}
涂亚平 committed
42
        </if>
涂亚平 committed
43
        <if test="companyId == null">
涂亚平 committed
44 45
            and t.company_id is null
        </if>
涂亚平 committed
46 47 48 49 50 51
        <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
52 53 54 55 56 57 58
        <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
59
            and t2.field_id = #{fieldId}
涂亚平 committed
60 61 62 63
        </if>
        <if test="rankId != null and rankId != ''">
            and t5.rank_id = #{rankId}
        </if>
涂亚平 committed
64 65 66
        <if test="openStatus != null and openStatus != ''">
            and t.open_status = #{openStatus}
        </if>
涂亚平 committed
67 68 69
        <if test="businessId != null and businessId != ''">
            and t6.business_id = #{businessId}
        </if>
涂亚平 committed
70 71 72
        <if test="courseDataType != null">
            and t.course_data_type = #{courseDataType}
        </if>
涂亚平 committed
73 74
    </select>

涂亚平 committed
75 76 77 78 79 80 81
    <sql id="Base_Column_List">
        create_date,
        update_date,
        delete_date,
        id, course_name, category_id, course_type, course_source
    </sql>

涂亚平 committed
82
    <select id="queryCourseMember" parameterType="com.subsidy.vo.member.StudyPageVO" resultType="com.subsidy.model.ClassMemberMappingDO">
涂亚平 committed
83
        SELECT
涂亚平 committed
84
            t3.*
涂亚平 committed
85 86
        FROM
            course_dict t
涂亚平 committed
87 88
            LEFT JOIN class_dict t2 ON t.id = t2.course_id
            LEFT JOIN class_member_mapping t3 ON t2.id = t3.member_id
涂亚平 committed
89 90
        WHERE
            t.delete_date IS NULL
涂亚平 committed
91 92 93 94 95 96 97 98 99 100 101 102 103 104 105
            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
106
            AND t.category_id = #{categoryId}
涂亚平 committed
107 108
        </if>
        <if test="courseName != null and courseName !=''">
涂亚平 committed
109
            AND t.course_name like concat('%',#{courseName} ,'%')
涂亚平 committed
110 111 112 113 114
        </if>
        <if test="courseSource != null and courseSource != ''">
            AND t.course_source = #{courseSource}
        </if>
        <if test="courseType != null and courseType !=''">
涂亚平 committed
115
            AND t.course_type = #{courseType}
涂亚平 committed
116 117
        </if>
            AND t.administer_id is null
涂亚平 committed
118 119
    </select>

涂亚平 committed
120
    <select id="queryCourseCnt" parameterType="long" resultType="integer">
涂亚平 committed
121
        SELECT
涂亚平 committed
122
            count( t2.id )
涂亚平 committed
123
        FROM
涂亚平 committed
124
            course_content t1
邓敏 committed
125 126
            LEFT JOIN content_vod_mapping t3 ON t3.content_id = t1.id
            LEFT JOIN vod_dict t2 ON t2.id = t3.vod_id
涂亚平 committed
127
        WHERE
涂亚平 committed
128 129
            t1.delete_date IS NULL
            AND t2.delete_date IS NULL
邓敏 committed
130
            AND t3.delete_date IS NULL
涂亚平 committed
131
            AND t1.course_id = #{courseId}
涂亚平 committed
132
    </select>
133

涂亚平 committed
134 135 136 137 138
    <select id="queryCoursePlayLength" parameterType="long" resultType="integer">
        SELECT
            sum( t2.vod_length )
        FROM
            course_content t1
邓敏 committed
139
            LEFT JOIN content_vod_mapping t3 ON t3.content_id = t1.id
涂亚平 committed
140
            LEFT JOIN vod_dict t2 ON t2.id = t3.vod_id
涂亚平 committed
141 142 143
        WHERE
            t1.delete_date IS NULL
            AND t2.delete_date IS NULL
邓敏 committed
144
            AND t3.delete_date IS NULL
涂亚平 committed
145 146
            AND t1.course_id = #{courseId}
    </select>
147

邓敏 committed
148 149 150 151 152 153 154 155 156 157 158 159 160 161
    <select id="getListByVodId" resultType="com.subsidy.model.CourseDictDO">
        SELECT
            t1.*
        FROM
            course_dict t1
            LEFT JOIN course_content t2 ON t2.course_id = t1.id
            LEFT JOIN content_vod_mapping t3 ON t3.content_id = t2.id
        WHERE
            t3.vod_id = #{vodId}
          AND t1.delete_date IS NULL
          AND t2.delete_date IS NULL
          AND t3.delete_date IS NULL
    </select>

涂亚平 committed
162 163 164
    <update id="updateOpenStatus">
        update course_dict set open_status = #{openStatus} where id = #{id}
    </update>
165

涂亚平 committed
166
</mapper>