xzs-mysql/source/xzs/src/main/resources/mapper/QuestionMapper.xml
2020-12-30 17:17:52 +08:00

293 lines
10 KiB
XML

<?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.QuestionMapper">
<resultMap id="BaseResultMap" type="com.mindskip.xzs.domain.Question">
<id column="id" jdbcType="INTEGER" property="id" />
<result column="question_type" jdbcType="INTEGER" property="questionType" />
<result column="subject_id" jdbcType="INTEGER" property="subjectId" />
<result column="industry_id" jdbcType="INTEGER" property="industryId" />
<result column="industry_name" jdbcType="VARCHAR" property="industryName" />
<result column="skill_id" jdbcType="INTEGER" property="skillId" />
<result column="skill_name" jdbcType="VARCHAR" property="skillName" />
<result column="score" jdbcType="INTEGER" property="score" />
<result column="grade_level" jdbcType="INTEGER" property="gradeLevel" />
<result column="difficult" jdbcType="INTEGER" property="difficult" />
<result column="correct" jdbcType="VARCHAR" property="correct" />
<result column="info_text_content_id" jdbcType="INTEGER" property="infoTextContentId" />
<result column="create_user" jdbcType="INTEGER" property="createUser" />
<result column="status" jdbcType="INTEGER" property="status" />
<result column="create_time" jdbcType="TIMESTAMP" property="createTime" />
<result column="deleted" jdbcType="BIT" property="deleted" />
</resultMap>
<sql id="Base_Column_List">
id, question_type, subject_id, industry_id, skill_id, score, grade_level, difficult, correct, info_text_content_id,
create_user, status, create_time, deleted
</sql>
<sql id="Page_Column_List">
q.id, q.question_type, q.subject_id, q.industry_id, i.name AS industry_name, q.skill_id, s.name AS skill_name, q.score, q.grade_level, q.difficult, q.correct, q.info_text_content_id,
q.create_user, q.status, q.create_time, q.deleted
</sql>
<select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from t_question
where id = #{id,jdbcType=INTEGER}
</select>
<delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">
delete from t_question
where id = #{id,jdbcType=INTEGER}
</delete>
<insert id="insert" parameterType="com.mindskip.xzs.domain.Question" useGeneratedKeys="true" keyProperty="id">
insert into t_question (id, question_type, subject_id,
score, grade_level, difficult,
correct, info_text_content_id, create_user,
status, create_time, deleted
)
values (#{id,jdbcType=INTEGER}, #{questionType,jdbcType=INTEGER}, #{subjectId,jdbcType=INTEGER},
#{score,jdbcType=INTEGER}, #{gradeLevel,jdbcType=INTEGER}, #{difficult,jdbcType=INTEGER},
#{correct,jdbcType=VARCHAR}, #{infoTextContentId,jdbcType=INTEGER}, #{createUser,jdbcType=INTEGER},
#{status,jdbcType=INTEGER}, #{createTime,jdbcType=TIMESTAMP}, #{deleted,jdbcType=BIT}
)
</insert>
<insert id="insertSelective" parameterType="com.mindskip.xzs.domain.Question" useGeneratedKeys="true" keyProperty="id">
insert into t_question
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="id != null">
id,
</if>
<if test="questionType != null">
question_type,
</if>
<if test="subjectId != null">
subject_id,
</if>
<if test="industryId != null">
industry_id,
</if>
<if test="skillId != null">
skill_id,
</if>
<if test="score != null">
score,
</if>
<if test="gradeLevel != null">
grade_level,
</if>
<if test="difficult != null">
difficult,
</if>
<if test="correct != null">
correct,
</if>
<if test="infoTextContentId != null">
info_text_content_id,
</if>
<if test="createUser != null">
create_user,
</if>
<if test="status != null">
status,
</if>
<if test="createTime != null">
create_time,
</if>
<if test="deleted != null">
deleted,
</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="id != null">
#{id,jdbcType=INTEGER},
</if>
<if test="questionType != null">
#{questionType,jdbcType=INTEGER},
</if>
<if test="subjectId != null">
#{subjectId,jdbcType=INTEGER},
</if>
<if test="industryId != null">
#{industryId,jdbcType=INTEGER},
</if>
<if test="skillId != null">
#{skillId,jdbcType=INTEGER},
</if>
<if test="score != null">
#{score,jdbcType=INTEGER},
</if>
<if test="gradeLevel != null">
#{gradeLevel,jdbcType=INTEGER},
</if>
<if test="difficult != null">
#{difficult,jdbcType=INTEGER},
</if>
<if test="correct != null">
#{correct,jdbcType=VARCHAR},
</if>
<if test="infoTextContentId != null">
#{infoTextContentId,jdbcType=INTEGER},
</if>
<if test="createUser != null">
#{createUser,jdbcType=INTEGER},
</if>
<if test="status != null">
#{status,jdbcType=INTEGER},
</if>
<if test="createTime != null">
#{createTime,jdbcType=TIMESTAMP},
</if>
<if test="deleted != null">
#{deleted,jdbcType=BIT},
</if>
</trim>
</insert>
<update id="updateByPrimaryKeySelective" parameterType="com.mindskip.xzs.domain.Question">
update t_question
<set>
<if test="questionType != null">
question_type = #{questionType,jdbcType=INTEGER},
</if>
<if test="subjectId != null">
subject_id = #{subjectId,jdbcType=INTEGER},
</if>
<if test="industryId != null">
industry_id = #{industryId,jdbcType=INTEGER},
</if>
<if test="skillId != null">
skill_id = #{skillId,jdbcType=INTEGER},
</if>
<if test="score != null">
score = #{score,jdbcType=INTEGER},
</if>
<if test="gradeLevel != null">
grade_level = #{gradeLevel,jdbcType=INTEGER},
</if>
<if test="difficult != null">
difficult = #{difficult,jdbcType=INTEGER},
</if>
<if test="correct != null">
correct = #{correct,jdbcType=VARCHAR},
</if>
<if test="infoTextContentId != null">
info_text_content_id = #{infoTextContentId,jdbcType=INTEGER},
</if>
<if test="createUser != null">
create_user = #{createUser,jdbcType=INTEGER},
</if>
<if test="status != null">
status = #{status,jdbcType=INTEGER},
</if>
<if test="createTime != null">
create_time = #{createTime,jdbcType=TIMESTAMP},
</if>
<if test="deleted != null">
deleted = #{deleted,jdbcType=BIT},
</if>
</set>
where id = #{id,jdbcType=INTEGER}
</update>
<update id="updateByPrimaryKey" parameterType="com.mindskip.xzs.domain.Question">
update t_question
set question_type = #{questionType,jdbcType=INTEGER},
subject_id = #{subjectId,jdbcType=INTEGER},
score = #{score,jdbcType=INTEGER},
grade_level = #{gradeLevel,jdbcType=INTEGER},
difficult = #{difficult,jdbcType=INTEGER},
correct = #{correct,jdbcType=VARCHAR},
info_text_content_id = #{infoTextContentId,jdbcType=INTEGER},
create_user = #{createUser,jdbcType=INTEGER},
status = #{status,jdbcType=INTEGER},
create_time = #{createTime,jdbcType=TIMESTAMP},
deleted = #{deleted,jdbcType=BIT}
where id = #{id,jdbcType=INTEGER}
</update>
<select id="page" resultMap="BaseResultMap" parameterType="com.mindskip.xzs.viewmodel.admin.question.QuestionPageRequestVM">
SELECT
<include refid="Page_Column_List"/>
FROM t_question AS q LEFT JOIN t_industry AS i ON q.industry_id = i.id LEFT JOIN t_skill AS s ON s.id = q.skill_id
<where>
q.deleted=0
<if test="id != null ">
and q.id= #{id}
</if>
<if test="level != null ">
and q.grade_level= #{level}
</if>
<if test="subjectId != null ">
and q.subject_id= #{subjectId}
</if>
<if test="questionType != null ">
and q.question_type= #{questionType}
</if>
<if test="industryId != null ">
and q.industry_id= #{industryId}
</if>
<if test="skillId != null ">
and q.skill_id= #{skillId}
</if>
</where>
</select>
<select id="selectQuestionsByQuestionsNumber"
resultMap="BaseResultMap">
<foreach collection="eachList" item="each" separator="union">
(select q.skill_id, q.industry_id, i.name as industry_name, s.name as skill_name
, t.content ,q.difficult ,q.question_type from t_industry i
join t_question q on i.id = q.industry_id
join t_skill s on s.id = q.skill_id
join t_text_content t on t.id = q.info_text_content_id
<where>
<if test="each.difficult != null">
and q.difficult = #{each.difficult}
</if>
<if test="each.industryId != null">
and i.id = #{each.industryId}
</if>
<if test="each.skillId != null">
and s.id = #{each.skillId}
</if>
</where>
limit #{each.eachNumber} )
</foreach>
</select>
<select id="selectAllSkills"
resultMap="BaseResultMap">
select id as skill_id,name as skill_name from t_skill
</select>
<select id="selectAllIndustry"
resultMap="BaseResultMap">
select id as industry_id,name as industry_name from t_industry
</select>
<select id="selectByIds" resultMap="BaseResultMap" >
SELECT
<include refid="Base_Column_List"/>
FROM t_question where id in
<foreach item="id" collection="ids" open="(" separator=","
close=")">
#{id}
</foreach>
</select>
<select id="selectAllCount" resultType="java.lang.Integer">
SELECT count(*) from t_question where deleted=0
</select>
<select id="selectCountByDate" resultType="com.mindskip.xzs.domain.other.KeyValue">
SELECT create_time as name,COUNT(create_time) as value from
(
SELECT DATE_FORMAT(create_time,'%Y-%m-%d') as create_time from t_question
WHERE deleted=0 and create_time between #{startTime} and #{endTime}
) a
GROUP BY create_time
</select>
</mapper>