Blame view

CourseDictMapper.xml 4.73 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 23
            t.open_status,
            t.cover_page
涂亚平 committed
24
        FROM
涂亚平 committed
25 26 27 28 29
            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
30
        WHERE
涂亚平 committed
31 32 33 34 35 36 37
            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
38
        </if>
涂亚平 committed
39
        <if test="companyId == null">
涂亚平 committed
40 41
            and t.company_id is null
        </if>
涂亚平 committed
42 43 44 45 46 47
        <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
48 49 50 51 52 53 54
        <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
55
            and t2.field_id = #{fieldId}
涂亚平 committed
56 57 58 59
        </if>
        <if test="rankId != null and rankId != ''">
            and t5.rank_id = #{rankId}
        </if>
涂亚平 committed
60 61 62
        <if test="openStatus != null and openStatus != ''">
            and t.open_status = #{openStatus}
        </if>
涂亚平 committed
63 64
    </select>

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

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

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

涂亚平 committed
122 123 124 125 126 127 128 129 130 131 132
    <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>
133

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

涂亚平 committed
138
</mapper>