forked from gzzfw/backEnd/gz-dyh

zhouxiantao
2024-09-14 6f4ed9dbb428374e5513fbf88aae1377fd423a51
dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/dao/mapper/xml/CaseInfoMapper.xml
@@ -70,6 +70,8 @@
            <result property="statusName" column="status_name"/>
            <result property="process" column="process"/>
            <result property="processName" column="process_name"/>
            <result property="infoProcess" column="info_process"/>
            <result property="infoProcessName" column="info_process_name"/>
            <result property="wantUnitId" column="want_unit_id"/>
            <result property="wantUnitName" column="want_unit_name"/>
            <result property="wantUserId" column="want_user_id"/>
@@ -79,8 +81,52 @@
            <result property="createTime" column="create_time"/>
            <result property="updateTime" column="update_time"/>
    </resultMap>
    <resultMap id="dataResult-all" type="cn.huge.module.cases.domain.dto.CasePageDTO">
        <result property="id" column="id"/>
        <result property="status" column="status"/>
        <result property="statusName" column="status_name"/>
        <result property="canal" column="canal"/>
        <result property="canalName" column="canal_name"/>
        <result property="caseLevel" column="case_level"/>
        <result property="caseType" column="case_type"/>
        <result property="caseTypeName" column="case_type_name"/>
        <result property="inputUnitId" column="input_unit_id"/>
        <result property="inputUnitName" column="input_unit_name"/>
        <result property="mediResult" column="medi_result"/>
        <result property="mediResultName" column="medi_result_name"/>
        <result property="mediateDeptId" column="mediate_dept_id"/>
        <result property="mediateDeptName" column="mediate_dept_name"/>
        <result property="assistUnitId" column="assist_unit_id"/>
        <result property="assistUnitName" column="assist_unit_name"/>
        <result property="closeTime" column="close_time"/>
        <result property="agreeType" column="agree_type"/>
        <result property="agreeTypeName" column="agree_type_name"/>
        <result property="agreeContent" column="agree_content"/>
    </resultMap>
    <!-- 表 -->
    <sql id='table-name'>dyh_case_info</sql>
    <sql id="column-part-all">
        a.id,
        a.status,
        a.status_name,
        a.canal,
        a.canal_name,
        a.case_level,
        a.case_type,
        a.case_type_name,
        a.input_unit_id,
        a.input_unit_name,
        b.medi_result,
        b.medi_result_name,
        b.mediate_dept_id,
        b.mediate_dept_name,
        b.assist_unit_id,
        b.assist_unit_name,
        b.close_time,
        b.agree_type,
        b.agree_type_name,
        b.agree_content
    </sql>
    <!-- 字段 -->
    <sql id="column-part">
        id,
@@ -142,6 +188,8 @@
        status_name,
        process,
        process_name,
        info_process,
        info_process_name,
        want_unit_id,
        want_unit_name,
        want_user_id,
@@ -211,6 +259,8 @@
            <if test="entity.statusName != null">status_name = #{entity.statusName},</if>
            <if test="entity.process != null">process = #{entity.process},</if>
            <if test="entity.processName != null">process_name = #{entity.processName},</if>
            <if test="entity.infoProcess != null">info_process = #{entity.infoProcess},</if>
            <if test="entity.infoProcessName != null">info_process_name = #{entity.infoProcessName},</if>
            <if test="entity.wantUnitId != null">want_unit_id = #{entity.wantUnitId},</if>
            <if test="entity.wantUnitName != null">want_unit_name = #{entity.wantUnitName},</if>
            <if test="entity.wantUserId != null">want_user_id = #{entity.wantUserId},</if>
@@ -221,9 +271,64 @@
            <if test="entity.updateTime != null">update_time = #{entity.updateTime}</if>
    </sql>
    <!-- 条件 -->
    <sql id="where-part-all">
        <if test="terms != null">
            <if test="terms.status != null and terms.status !=''">
                and a.status = #{terms.status}
            </if>
            <if test="terms.statusName != null and terms.statusName !=''">
                and a.status_name = #{terms.statusName}
            </if>
            <if test="terms.canal != null and terms.canal !=''">
                and a.canal = #{terms.canal}
            </if>
            <if test="terms.canalName != null and terms.canalName !=''">
                and a.canal_name = #{terms.canalName}
            </if>
            <if test="terms.caseLevel != null and terms.caseLevel !=''">
                and a.case_level = #{terms.caseLevel}
            </if>
            <if test="terms.caseType != null and terms.caseType !=''">
                and a.case_type = #{terms.caseType}
            </if>
            <if test="terms.caseTypeName != null and terms.caseTypeName !=''">
                and a.case_type_name = #{terms.caseTypeName}
            </if>
            <if test="terms.inputUnitId != null and terms.inputUnitId !=''">
                and a.input_unit_id = #{terms.inputUnitId}
            </if>
            <if test="terms.inputUnitName != null and terms.inputUnitName !=''">
                and a.input_unit_name = #{terms.inputUnitName}
            </if>
            <if test="terms.visitTimeStart != null and terms.visitTimeStart !='' and terms.visitTimeEnd != null and terms.visitTimeEnd !=''">
                and (DATE_FORMAT(a.visit_time,'%Y-%m-%d %H:%i:%s') <![CDATA[ >= ]]> #{terms.visitTimeStart}
                and DATE_FORMAT(a.visit_time,'%Y-%m-%d %H:%i:%s') <![CDATA[ <= ]]> #{terms.visitTimeEnd})
            </if>
            <if test="terms.createStart != null and terms.createStart !='' and terms.createEnd != null and terms.createEnd !=''">
                and (DATE_FORMAT(a.create_time,'%Y-%m-%d %H:%i:%s') <![CDATA[ >= ]]> #{terms.createStart}
                and DATE_FORMAT(a.create_time,'%Y-%m-%d %H:%i:%s') <![CDATA[ <= ]]> #{terms.createEnd})
            </if>
            <if test="terms.closeStart != null and terms.closeStart !='' and terms.closeEnd != null and terms.closeEnd !=''">
                and (DATE_FORMAT(b.close_time,'%Y-%m-%d %H:%i:%s') <![CDATA[ >= ]]> #{terms.closeStart}
                and DATE_FORMAT(b.close_time,'%Y-%m-%d %H:%i:%s') <![CDATA[ <= ]]> #{terms.closeEnd})
            </if>
            <if test="terms.fileStart != null and terms.fileStart !='' and terms.fileEnd != null and terms.fileEnd !=''">
                and (DATE_FORMAT(b.file_time,'%Y-%m-%d %H:%i:%s') <![CDATA[ >= ]]> #{terms.fileStart}
                and DATE_FORMAT(b.file_time,'%Y-%m-%d %H:%i:%s') <![CDATA[ <= ]]> #{terms.fileEnd})
            </if>
        </if>
    </sql>
    <!-- 条件 -->
    <sql id="where-part">
        <if test="terms != null">
            <where>
                <if test="terms.ids != null and terms.ids.size > 0">
                    and id in
                    <foreach collection="terms.ids" item="id" index="index" open="(" separator="," close=")">
                        #{id}
                    </foreach>
                </if>
                <if test="terms.id != null and terms.id !=''">
                    and id = #{terms.id}
                </if>
@@ -395,11 +500,23 @@
                <if test="terms.statusName != null and terms.statusName !=''">
                    and status_name = #{terms.statusName}
                </if>
                <if test="terms.processList != null and terms.processList.size > 0">
                    and process in
                    <foreach collection="terms.processList" item="process" index="index" open="(" separator="," close=")">
                        #{process}
                    </foreach>
                </if>
                <if test="terms.process != null and terms.process !=''">
                    and process = #{terms.process}
                </if>
                <if test="terms.processName != null and terms.processName !=''">
                    and process_name = #{terms.processName}
                </if>
                <if test="terms.infoProcess != null and terms.infoProcess !=''">
                    and info_process = #{terms.infoProcess}
                </if>
                <if test="terms.infoProcessName != null and terms.infoProcessName !=''">
                    and info_process_name = #{terms.infoProcessName}
                </if>
                <if test="terms.wantUnitId != null and terms.wantUnitId !=''">
                    and want_unit_id = #{terms.wantUnitId}
@@ -440,6 +557,21 @@
        </if>
    </sql>
    <!-- 更新对象 -->
    <update id="updateCaseInfoList">
        update
        <include refid="table-name"/>
        <set>
            <include refid="set-part"/>
        </set>
        <where>
            id IN
            <foreach item="id" collection="caseIdList" open="(" separator="," close=")">
                #{id}
            </foreach>
        </where>
    </update>
    <!-- 批量更新对象 -->
    <update id="updateCaseInfo">
        update
        <include refid="table-name"/>
@@ -450,6 +582,7 @@
            id = #{entity.id}
        </where>
    </update>
    <!-- 条件更新对象 -->
    <update id="updateCaseInfoTerms">
        update
@@ -499,4 +632,31 @@
        limit #{page.offset}, #{page.size}
    </select>
    <!--  根据条件统计  -->
    <select id="countTermsAll" resultType="java.lang.Long">
        select
        COUNT(1)
        from
        dyh_case_info a LEFT JOIN dyh_case_info_unfold b on a.id = b.id
        <include refid="where-part-all"/>
    </select>
    <!--  根据条件分页查询  -->
    <select id="pageTermsAll" resultMap="dataResult-all">
        SELECT
        <include refid="column-part-all"/>
        FROM
        dyh_case_info a LEFT JOIN dyh_case_info_unfold b on a.id = b.id
        <include refid="where-part-all"/>
        <if test="page.sort != null">
            <foreach collection="page.sort" item="s" index="index" separator="," open="order by ">
                isnull(${s.property}), ${s.property} ${s.direction}
            </foreach>
        </if>
        <if test="page.sort == null">
            order by isnull(a.create_time), a.create_time desc
        </if>
        limit #{page.offset}, #{page.size}
    </select>
</mapper>