<?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.mindskip.xzs.repository.ClassesUserMapper">
|
<resultMap id="BaseResultMap" type="com.mindskip.xzs.domain.ClassesUser">
|
<id column="id" jdbcType="INTEGER" property="id" />
|
<result column="classes_id" jdbcType="INTEGER" property="classesId" />
|
<result column="user_id" jdbcType="INTEGER" property="userId" />
|
<result column="create_time" jdbcType="TIMESTAMP" property="createTime" />
|
<result column="deleted" jdbcType="BIT" property="deleted" />
|
<result column="classes_name" jdbcType="VARCHAR" property="classesName" />
|
</resultMap>
|
<sql id="Base_Column_List">
|
id, classes_id, user_id, create_time, deleted, classes_name
|
</sql>
|
<select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="BaseResultMap">
|
select
|
<include refid="Base_Column_List" />
|
from t_classes_user
|
where id = #{id,jdbcType=INTEGER}
|
</select>
|
<delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">
|
delete from t_classes_user
|
where id = #{id,jdbcType=INTEGER}
|
</delete>
|
<insert id="insert" parameterType="com.mindskip.xzs.domain.ClassesUser" useGeneratedKeys="true" keyProperty="id">
|
insert into t_classes_user (id, classes_id, user_id,
|
create_time, deleted, classes_name
|
)
|
values (#{id,jdbcType=INTEGER}, #{classesId,jdbcType=INTEGER}, #{userId,jdbcType=INTEGER},
|
#{createTime,jdbcType=TIMESTAMP}, #{deleted,jdbcType=BIT}, #{classesName,jdbcType=VARCHAR}
|
)
|
</insert>
|
<insert id="insertSelective" parameterType="com.mindskip.xzs.domain.ClassesUser" useGeneratedKeys="true" keyProperty="id">
|
insert into t_classes_user
|
<trim prefix="(" suffix=")" suffixOverrides=",">
|
<if test="id != null">
|
id,
|
</if>
|
<if test="classesId != null">
|
classes_id,
|
</if>
|
<if test="userId != null">
|
user_id,
|
</if>
|
<if test="createTime != null">
|
create_time,
|
</if>
|
<if test="deleted != null">
|
deleted,
|
</if>
|
<if test="classesName != null">
|
classes_name,
|
</if>
|
</trim>
|
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
<if test="id != null">
|
#{id,jdbcType=INTEGER},
|
</if>
|
<if test="classesId != null">
|
#{classesId,jdbcType=INTEGER},
|
</if>
|
<if test="userId != null">
|
#{userId,jdbcType=INTEGER},
|
</if>
|
<if test="createTime != null">
|
#{createTime,jdbcType=TIMESTAMP},
|
</if>
|
<if test="deleted != null">
|
#{deleted,jdbcType=BIT},
|
</if>
|
<if test="classesName != null">
|
#{classesName,jdbcType=VARCHAR},
|
</if>
|
</trim>
|
</insert>
|
<update id="updateByPrimaryKeySelective" parameterType="com.mindskip.xzs.domain.ClassesUser">
|
update t_classes_user
|
<set>
|
<if test="classesId != null">
|
classes_id = #{classesId,jdbcType=INTEGER},
|
</if>
|
<if test="userId != null">
|
user_id = #{userId,jdbcType=INTEGER},
|
</if>
|
<if test="createTime != null">
|
create_time = #{createTime,jdbcType=TIMESTAMP},
|
</if>
|
<if test="deleted != null">
|
deleted = #{deleted,jdbcType=BIT},
|
</if>
|
<if test="classesName != null">
|
classes_name = #{classesName,jdbcType=VARCHAR},
|
</if>
|
</set>
|
where id = #{id,jdbcType=INTEGER}
|
</update>
|
<update id="updateByPrimaryKey" parameterType="com.mindskip.xzs.domain.ClassesUser">
|
update t_classes_user
|
set classes_id = #{classesId,jdbcType=INTEGER},
|
user_id = #{userId,jdbcType=INTEGER},
|
create_time = #{createTime,jdbcType=TIMESTAMP},
|
deleted = #{deleted,jdbcType=BIT},
|
classes_name = #{classesName,jdbcType=VARCHAR}
|
where id = #{id,jdbcType=INTEGER}
|
</update>
|
|
|
|
|
<select id="getClassesUser" resultMap="BaseResultMap">
|
select
|
<include refid="Base_Column_List" />
|
from t_classes_user
|
where deleted=0
|
and user_id = #{uid,jdbcType=INTEGER}
|
and classes_id = #{classesId,jdbcType=INTEGER}
|
limit 1
|
</select>
|
|
|
|
|
<resultMap id="ClassesUserInfoResultMap" type="com.mindskip.xzs.domain.classes.ClassesUserInfo">
|
<id column="id" jdbcType="INTEGER" property="id" />
|
<id column="uId" jdbcType="INTEGER" property="uId" />
|
<result column="user_name" jdbcType="VARCHAR" property="userName" />
|
<result column="real_name" jdbcType="VARCHAR" property="realName" />
|
<result column="sex" jdbcType="INTEGER" property="sex" />
|
<result column="user_level" jdbcType="INTEGER" property="userLevel" />
|
<result column="phone" jdbcType="VARCHAR" property="phone" />
|
<result column="join_time" jdbcType="TIMESTAMP" property="joinTime" />
|
<result column="classes_name" jdbcType="VARCHAR" property="classesName" />
|
</resultMap>
|
|
|
<select id="classesUserPageList" parameterType="com.mindskip.xzs.viewmodel.teacher.classes.ClassesUserPageRequestVM" resultMap="ClassesUserInfoResultMap">
|
SELECT c.id,u.id as uId,u.user_name,u.real_name,u.real_name,u.sex,u.user_level,u.phone,c.create_time as join_time,c.classes_name from t_user u
|
LEFT JOIN t_classes_user c on u.id=c.user_id
|
WHERE u.deleted=0 and c.deleted=0
|
<if test="userName != null ">
|
and u.user_name like concat('%',#{userName},'%')
|
</if>
|
and c.classes_id in
|
<choose>
|
<when test="classesIds != null and classesIds.size>0">
|
<foreach item="id" collection="classesIds" open="(" separator=","
|
close=")">
|
#{id}
|
</foreach>
|
</when>
|
<otherwise>
|
(0)
|
</otherwise>
|
</choose>
|
</select>
|
|
|
<select id="getJoinClasses" resultMap="BaseResultMap">
|
select
|
<include refid="Base_Column_List" />
|
from t_classes_user
|
where deleted=0
|
and user_id = #{uid,jdbcType=INTEGER}
|
</select>
|
|
|
|
<select id="getClassCount" resultType="com.mindskip.xzs.domain.other.KeyValue">
|
select classes_name as name,count(user_id) as value from t_classes_user WHERE deleted=0
|
AND classes_id in
|
<choose>
|
<when test="classIds != null and classIds.size > 0">
|
<foreach item="id" collection="classIds" open="(" separator=","
|
close=")">
|
#{id}
|
</foreach>
|
</when>
|
<otherwise>
|
(0)
|
</otherwise>
|
</choose>
|
GROUP BY classes_name
|
</select>
|
|
</mapper>
|