Newer
Older
casic-metering / casic-metering-dao / src / main / resources / mapper / business / BusinessOrderSampleRelationMapper.xml
wangpeng on 28 Mar 2023 9 KB 分包方项目申请模块
<?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.casic.missiles.mapper.business.BusinessOrderSampleRelationMapper">

    <!-- 通用查询映射结果 -->
    <resultMap id="BaseResultMap" type="com.casic.missiles.model.business.BusinessOrderSampleRelation">
        <id column="id" property="id"/>
        <result column="order_id" property="orderId"/>
        <result column="sample_id" property="sampleId"/>
        <result column="sample_status" property="sampleStatus"/>
    </resultMap>

    <!-- 通用查询结果列 -->
    <sql id="Base_Column_List">
        id, order_id, sample_id, sample_status
    </sql>

    <!-- 各状态列表查询结果列 -->
    <sql id="Status_Column_List">
        csi.id AS sample_id, csi.sample_no, csi.sample_name, csi.sample_model, csi.manufacturing_no, bo.order_code AS orderNo, bo.id AS orderId,
        bo.customer_id, bo.customer_no, bo.customer_name, bo.deliverer, bo.is_urgent, csi.sample_belong, bo.require_over_time, bosr.sample_status
    </sql>

    <!-- 详情查询结果列 -->
    <sql id="Detail_Column_List">
        bosr.sample_id, csi.sample_no, csi.sample_name, csi.sample_model, csi.manufacturing_no, csi.manufacturer, csi.manufacturer_country,
        csi.manufacturing_date, csi.ABC, bo.customer_id, bo.customer_no, bo.customer_name, bo.customer_phone, bo.customer_address, bo.id AS orderId,
        bo.order_code, bo.deliverer, bo.deliverer_tel, bo.plan_deliver_time, bo.require_over_time, bo.certifications, bosr.measure_content, csi.measure_period,
        csi.measure_last_time AS measureLastDate, csi.valid_deadline AS effectiveDate, bosr.remark, csi.minio_file_name, bosr.measure_type, csi.label_bind
    </sql>

    <select id="getSampleListByStatus" resultType="com.casic.missiles.dto.business.dispatch.DeviceDispatchVO">
        SELECT bosr.id,csi.id AS "sampleId", csi.sample_no, csi.sample_name, csi.sample_model, csi.manufacturing_no,bo.order_code,
        bo.id AS orderId,bo.customer_id,bo.customer_name,bo.customer_no,bo.deliverer,bo.is_urgent,csi.sample_belong,
        bo.require_over_time,bosr.sample_status,bosr.real_deliver_time AS "realDeliverTime",csi.measure_type AS "measureType",
        bo.is_urgent AS "isUrgent",plan_deliver_time  AS "planDeliverTime",bo.require_over_time AS "requireOverTime",bo.deliverer
        FROM
        (
            SELECT *
            FROM business_order bo
            WHERE bo.is_del = 0
            <if test="request.sampleStatus == 8"><!--超期状态,样品在待分发和检测中下的超期-->
                AND bo.require_over_time &lt; NOW()
            </if>
            <if test="request.orderNo != null and request.orderNo !=''">
                AND bo.order_code LIKE concat('%',#{request.orderNo},'%')
            </if>
            <if test="request.customerNo != null and request.customerNo !=''">
                AND bo.customer_no LIKE concat('%',#{request.customerNo},'%')
            </if>
            <if test="request.startTime != null and request.startTime !=''">
                AND bo.require_over_time &gt;= #{request.startTime}
            </if>
            <if test="request.endTime != null and request.endTime !=''">
                AND bo.require_over_time &lt; #{request.endTime}
            </if>
            <if test="request.isUrgent != null and request.isUrgent !=2 ">
                AND bo.is_urgent = #{request.isUrgent}
            </if>
        ) bo
        JOIN
        (
            SELECT *
            FROM business_order_sample_relation bosr
            WHERE 1=1
            <if test="request.sampleStatus == 2"><!--超期状态,样品在待分发和检测中下的超期-->
                AND (bosr.sample_status = 2 OR bosr.sample_status = 3 OR bosr.sample_status = 4 )
            </if>
            <if test="request.sampleStatus == 8"><!--超期状态,样品在待分发和检测中下的超期-->
                AND (bosr.sample_status = 2 OR bosr.sample_status = 3)
            </if>
            <if test="request.sampleStatus != null and request.sampleStatus != 8"><!--非超期状态的其它状态-->
                AND bosr.sample_status = #{request.sampleStatus}
            </if>
            <if test="request.ids != null">
                and id in
                <foreach collection="request.ids" item="id" index="index" open="(" close=")" separator=",">
                    #{id}
                </foreach>
            </if>
        ) bosr ON bo.id = bosr.order_id
        JOIN (
            SELECT *
            FROM customer_sample_info csi
            WHERE is_del=0
            <if test="request.sampleNo != null and request.sampleNo !=''">
                AND csi.sample_no LIKE concat('%',#{request.sampleNo},'%')
            </if>
            <if test="request.sampleName != null and request.sampleName !=''">
                AND csi.sample_name LIKE concat('%',#{request.sampleName},'%')
            </if>
            <if test="request.sampleBelong != null and request.sampleBelong !=''and request.sampleBelong !=2 ">
                AND csi.sample_belong = #{request.sampleBelong}
            </if>
        ) csi ON csi.id = bosr.sample_id
    </select>

    <select id="selectSampleListByStatus" resultType="com.casic.missiles.dto.business.SampleHandOutListResponse">
        SELECT
        <include refid="Status_Column_List"/>
        FROM business_order bo
        JOIN business_order_sample_relation bosr ON bo.id = bosr.order_id
        JOIN customer_sample_info csi ON csi.id = bosr.sample_id
        WHERE bo.is_del = 0
        AND bosr.measure_type = 1<!--检定方式:内检-->
        <if test="request.sampleStatus == 8"><!--超期状态,样品在待分发和检测中下的超期-->
            AND (bosr.sample_status = 2 OR bosr.sample_status = 3)
            AND bo.require_over_time &lt; NOW()
        </if>
        <if test="request.sampleStatus != 8"><!--非超期状态的其它状态-->
            AND bosr.sample_status = #{request.sampleStatus}
        </if>
        <if test="request.sampleNo != null and request.sampleNo !=''">
            AND csi.sample_no LIKE concat('%',#{request.sampleNo},'%')
        </if>
        <if test="request.sampleName != null and request.sampleName !=''">
            AND csi.sample_name LIKE concat('%',#{request.sampleName},'%')
        </if>
        <if test="request.orderNo != null and request.orderNo !=''">
            AND bo.order_code LIKE concat('%',#{request.orderNo},'%')
        </if>
        <if test="request.customerNo != null and request.customerNo !=''">
            AND bo.customer_no LIKE concat('%',#{request.customerNo},'%')
        </if>
        <if test="request.customerName != null and request.customerName !=''">
            AND bo.customer_name LIKE concat('%',#{request.customerName},'%')
        </if>
        <if test="request.startTime != null and request.startTime !=''">
            AND bo.require_over_time &gt;= #{request.startTime}
        </if>
        <if test="request.endTime != null and request.endTime !=''">
            AND bo.require_over_time &lt; #{request.endTime}
        </if>
        <if test="request.isUrgent != null and request.isUrgent !=''">
            AND bo.is_urgent = #{request.isUrgent}
        </if>
        <if test="request.sampleBelong != null and request.sampleBelong !=''">
            AND csi.sample_belong = #{request.sampleBelong}
        </if>
        <if test="request.ids != null">
            AND csi.id IN
            <foreach collection="request.ids" item="item" index="index" open="(" close=")" separator=",">
                #{item}
            </foreach>
        </if>
        ORDER BY bosr.update_time DESC
    </select>

    <select id="selectSampleDetail" resultType="com.casic.missiles.dto.business.SampleHandOutDetailResponse">
        SELECT
        <include refid="Detail_Column_List"/>
        FROM business_order_sample_relation bosr
        JOIN customer_sample_info csi ON bosr.sample_id = csi.id
        JOIN business_order bo ON bosr.order_id = bo.id
        WHERE bo.is_del = 0 AND csi.is_del = 0
        AND bosr.order_id = #{orderId}
        AND bosr.sample_id = #{sampleId}
    </select>

    <update id="updateByOrderIdAndSampleId">
        UPDATE business_order_sample_relation
        SET sample_status = #{status}
        WHERE order_id = #{orderId} AND sample_id = #{sampleId}
    </update>


    <select id="getInterChangeSampleList" resultType="com.casic.missiles.dto.customer.sample.CustomerSampleListVO">
        SELECT sampleNo,sampleName,sampleModel,manufacturingNo,appendixDescn,id,remark,sampleId,measureContent,orderId
        FROM
        (
          SELECT sample_no AS "sampleNo",sample_name AS "sampleName",sample_model AS "sampleModel",manufacturing_no AS "manufacturingNo",appendix_descn AS "appendixDescn",id,remark
          FROM customer_sample_info
          WHERE is_del=0 AND id=#{sampleId}
        )bo
        JOIN (
            SELECT measure_content AS "measureContent",sample_id AS "sampleId",order_id AS  "orderId"
            FROM business_order_sample_relation
            WHERE order_id=#{orderId}
            AND sample_id=#{sampleId}
         )bosr ON  bosr.sampleId=bo.id
    </select>

</mapper>