Blame view

AdministerMapper.xml 9.76 KB
涂亚平 committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
<?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.AdministerMapper">

    <!-- 通用查询映射结果 -->
    <resultMap id="BaseResultMap" type="com.subsidy.model.AdministerDO">
        <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="telephone" property="telephone" />
        <result column="password" property="password" />
        <result column="user_name" property="userName" />
        <result column="img" property="img" />
        <result column="status" property="status" />
    </resultMap>

    <!-- 通用查询结果列 -->
    <sql id="Base_Column_List">
        create_date,
        update_date,
        delete_date,
        id, telephone, password, user_name, short_name, img, banner, status, field
    </sql>

    <select id="getPermissions" resultType="com.subsidy.vo.administer.PermissionsVO">
        SELECT DISTINCT
        t4.*
        FROM
        role_administer_mapping t
        LEFT JOIN role_dict t2 ON t.role_id = t2.id
        LEFT JOIN role_permission_mapping t3 ON t2.id = t3.role_id
        LEFT JOIN permissions_dict t4 ON t3.permission_id = t4.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
        <if test="id !=null and id !=''">
            and t.administer_id = #{id}
        </if>

    </select>

涂亚平 committed
45 46 47 48
    <select id="classMembers" resultType="com.subsidy.vo.classdict.ClassDetailVO">
        SELECT
            t2.id,
            t2.user_name,
涂亚平 committed
49
            t2.gender,
涂亚平 committed
50
            t2.id_card,
涂亚平 committed
51
            t2.account_name,
涂亚平 committed
52
            t2.telephone,
涂亚平 committed
53 54
            t.email,
            t3.company_name
涂亚平 committed
55 56 57
        FROM
            class_member_mapping t
            LEFT JOIN member t2 ON t.member_id = t2.id
涂亚平 committed
58
            left join company_dict t3 on t2.company_id = t3.id
涂亚平 committed
59 60 61 62 63 64
             where t.delete_date IS NULL
            AND t2.delete_date IS NULL
            AND t.class_id = #{classId}
            <if  test="userName != null and userName !=''">
                and t2.user_name like concat('%',#{userName} ,'%')
            </if>
涂亚平 committed
65
        order by t2.account_name ASC
涂亚平 committed
66 67 68 69 70 71 72
    </select>

    <select id="classSign" resultType="com.subsidy.vo.member.ClassSignVO">
        SELECT
        t2.id,
        t2.user_name,
        t2.account_name,
涂亚平 committed
73
        t2.telephone,
涂亚平 committed
74 75
        t2.id_card,
        t3.company_name
涂亚平 committed
76 77 78
        FROM
        class_member_mapping t
        LEFT JOIN member t2 ON t.member_id = t2.id
涂亚平 committed
79
        left join company_dict t3 on t2.company_id = t3.id
涂亚平 committed
80 81 82 83 84 85
        where t.delete_date IS NULL
        AND t2.delete_date IS NULL
        AND t.class_id = #{classId}
        <if  test="userName != null and userName !=''">
            and t2.user_name like concat('%',#{userName} ,'%')
        </if>
涂亚平 committed
86
        order by t2.account_name ASC
涂亚平 committed
87 88 89 90 91 92 93
    </select>

    <select id="exerciseTest" resultType="com.subsidy.vo.administer.ExerciseTestVO">
        SELECT
        t2.id,
        t2.user_name,
        t2.account_name,
涂亚平 committed
94
        t2.telephone,
涂亚平 committed
95 96
        t2.id_card,
        t3.company_name
涂亚平 committed
97 98 99
        FROM
        class_member_mapping t
        LEFT JOIN member t2 ON t.member_id = t2.id
涂亚平 committed
100
        left join company_dict t3 on t2.company_id = t3.id
涂亚平 committed
101 102 103 104 105 106
        where t.delete_date IS NULL
        AND t2.delete_date IS NULL
        AND t.class_id = #{classId}
        <if  test="userName != null and userName !=''">
            and t2.user_name like concat('%',#{userName} ,'%')
        </if>
涂亚平 committed
107
        order by t2.account_name ASC
涂亚平 committed
108 109 110
    </select>

    <select id="answerRecord" resultType="com.subsidy.vo.sign.AnswerRecordVO">
涂亚平 committed
111 112
        SELECT
            t.id,
涂亚平 committed
113 114 115 116
            t.title,
            t.answer,
            t2.user_name,
            t.create_date,
涂亚平 committed
117 118
            t.update_date,
            t3.company_name
涂亚平 committed
119
        FROM
涂亚平 committed
120 121
            answering_question t
            LEFT JOIN member t2 ON t.ask_id = t2.id
涂亚平 committed
122
            left join company_dict t3 on t2.company_id = t3.id
涂亚平 committed
123 124
        WHERE
            t.delete_date IS NULL
涂亚平 committed
125 126 127 128
            AND t.class_id = #{classId}
            <if test="userName !=null and userName !=''">
                AND t2.user_name LIKE  concat('%',#{userName} ,'%')
            </if>
涂亚平 committed
129
        order by t2.account_name ASC
涂亚平 committed
130 131
    </select>

涂亚平 committed
132 133 134 135 136 137 138
    <select id="classActivityDetection" resultType="com.subsidy.vo.administer.MemberDetectionRecordVO">
        SELECT
        t2.id,
        t2.user_name,
        t2.account_name,
        t2.telephone,
        t2.id_card,
涂亚平 committed
139
        t4.company_name,
涂亚平 committed
140 141 142 143 144
        count( t3.id ) as cnt
        FROM
        class_member_mapping t
        LEFT JOIN member t2 ON t.member_id = t2.id
        LEFT JOIN activity_detection t3 ON t.class_id = t3.class_id
涂亚平 committed
145
        AND t.member_id = t3.member_id and t3.delete_date IS NULL
涂亚平 committed
146
        left join company_dict t4 on t2.company_id = t4.id
涂亚平 committed
147 148 149 150 151 152 153 154
        where t.delete_date IS NULL
        AND t2.delete_date IS NULL
        AND t.class_id = #{classId}
        <if  test="userName != null and userName !=''">
            and t2.user_name like concat('%',#{userName} ,'%')
        </if>
        GROUP BY
        t.member_id
涂亚平 committed
155
        order by t2.account_name ASC
涂亚平 committed
156 157
    </select>

涂亚平 committed
158 159 160 161 162 163
    <select id="imageCheckDetail" resultType="com.subsidy.vo.administer.ImageCheckDetailVO">
        SELECT
            t1.id,
            t1.user_name,
            t1.account_name,
            t1.telephone,
涂亚平 committed
164
            t1.company_name,
涂亚平 committed
165 166 167 168 169 170 171 172 173 174 175
            t1.id_card,
            cnt,
            recentDate
        FROM
            (
            SELECT
                t2.id,
                t2.user_name,
                t2.account_name,
                t2.telephone,
                t2.id_card,
涂亚平 committed
176
                t4.company_name,
涂亚平 committed
177 178 179 180 181
                count( t3.id ) AS cnt
            FROM
                class_member_mapping t
                LEFT JOIN member t2 ON t.member_id = t2.id
                LEFT JOIN image_check_record t3 ON t.class_id = t3.class_id
涂亚平 committed
182
                AND t.member_id = t3.member_id and t3.delete_date IS NULL
涂亚平 committed
183 184
                left join company_dict t4 on t2.company_id = t4.id
        WHERE
涂亚平 committed
185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205
                t.delete_date IS NULL
                AND t2.delete_date IS NULL
                <if  test="userName != null and userName !=''">
                    and t2.user_name like concat('%',#{userName} ,'%')
                </if>
                AND t.class_id = #{classId}
            GROUP BY
                t.member_id
            ) t1
            LEFT JOIN (
            SELECT
                t2.member_id,
                t2.class_id,
                max( t2.create_date ) AS recentDate
            FROM
                image_check_record t2
            WHERE
                t2.delete_date IS NULL
                AND t2.class_id = #{classId}
            GROUP BY
                t2.member_id,
206
                t2.class_id
涂亚平 committed
207
            ) t2 ON t1.id = t2.member_id
涂亚平 committed
208
        order by t1.account_name ASC
涂亚平 committed
209 210 211 212 213 214 215 216 217 218 219 220 221 222 223
    </select>

    <select id="operators" parameterType="string" resultType="com.subsidy.vo.administer.OperatorsVO">
        SELECT
        t.id,
        t.user_name,
        t.account_name
        FROM
        administer t
        WHERE
        t.role = 0
        AND t.delete_date IS NULL
        <if test="userName != null and userName != ''">
            and t.user_name like concat('%',#{userName} ,'%')
        </if>
涂亚平 committed
224 225
    </select>

226
    <select id="selfExport" parameterType="com.subsidy.model.ClassDictDO" resultType="com.subsidy.dto.administer.SelfExportVO">
涂亚平 committed
227
      SELECT
228
        t3.user_name,
涂亚平 committed
229 230
        t7.vodName,
        DATE_SUB( t1.create_date, INTERVAL (t1.play_length + t1.suspend_length) SECOND ) AS startTime,
231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247
        t1.create_date AS endTime,
        SEC_TO_TIME( t1.play_length ) playLength,
        IF
        (
        t2.total_length &lt; t1.vod_length,
        SEC_TO_TIME( t2.total_length ),
        SEC_TO_TIME( t1.vod_length )) AS studyLength,
        SEC_TO_TIME( t1.vod_length ) vodLength
        FROM
        (
        SELECT
        t.member_id,
        t.class_id,
        t.vod_id,
        t.create_date,
        t2.vod_name,
        t.play_length,
涂亚平 committed
248 249
        t2.vod_length,
        t.suspend_length
250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272
        FROM
        vod_play_history t
        LEFT JOIN vod_dict t2 ON t.vod_id = t2.id
        WHERE
        t.class_id = #{id}
        AND t.delete_date IS NULL
        ) t1
        LEFT JOIN (
        SELECT
        t.member_id,
        t.class_id,
        t.vod_id,
        sum( t.play_length ) AS total_length
        FROM
        vod_play_history t
        LEFT JOIN vod_dict t2 ON t.vod_id = t2.id
        GROUP BY
        t.member_id,
        t.class_id,
        t.vod_id
        ) t2 ON t1.vod_id = t2.vod_id
        AND t1.member_id = t2.member_id
        AND t1.class_id = t2.class_id
涂亚平 committed
273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290
        LEFT JOIN (
        SELECT
        t5.id,
        IFNULL( t4.vod_alias_name, t5.vod_name ) AS vodName
        FROM
        class_dict t1
        LEFT JOIN course_dict t2 ON t1.course_id = t2.id
        LEFT JOIN course_content t3 ON t2.id = t3.course_id
        LEFT JOIN content_vod_mapping t4 ON t3.id = t4.content_id
        LEFT JOIN vod_dict t5 ON t5.id = t4.vod_id
        WHERE
        t1.id = #{id}
        AND t1.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
        ) t7 ON t1.vod_id = t7.id
291 292 293 294 295 296 297 298 299 300 301 302 303
        LEFT JOIN member t3 ON t1.member_id = t3.id
        LEFT JOIN class_member_mapping t6 ON t3.id = t6.member_id
        AND t6.class_id = t1.class_id
        LEFT JOIN class_dict t4 ON t1.class_id = t4.id
        LEFT JOIN company_dict t5 ON t3.company_id = t5.id
        WHERE
        t6.delete_date IS NULL
        ORDER BY
        t1.member_id,
        t1.class_id,
        t1.create_date
    </select>

涂亚平 committed
304
</mapper>