<?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.customer.CustomerSampleMapper">
<select id="selectMaxSampleNo" resultType="Long">
SELECT IFNULL(MAX(RIGHT (sample_no, 12)), 0)
FROM customer_sample_info
</select>
<select id="measureRecordsById" resultType="com.casic.missiles.dto.customer.MeasureRecordsResponse">
SELECT order_id AS orderId,order_code AS orderCode,order_time AS orderTime,
customer_no AS customerCode,customer_name AS customerName,deliverer,real_deliver_time AS deliverTime
FROM
(
SELECT id
FROM customer_sample_info csi
WHERE csi.is_del =0
<if test="request.sampleId != null and request.sampleId !=''">
AND csi.id=#{request.sampleId}
</if>
<if test="request.customerId != null and request.customerId !=''">
AND csi.customer_id=#{request.customerId }
</if>
)csi
JOIN
(
SELECT sample_id,order_id,real_deliver_time
FROM business_order_sample_relation
WHERE 1=1
<if test="request.sampleId != null and request.sampleId !=''">
AND sample_id=#{request.sampleId}
</if>
)bosr ON bosr.sample_id=csi.id
JOIN (
SELECT *
FROM business_order
WHERE is_del =0
<if test="request.customerId != null and request.customerId !=''">
AND customer_id=#{request.customerId}
</if>
)bo ON bo.id=bosr.order_id
ORDER BY bosr.real_deliver_time DESC
</select>
<select id="samplesByOderId" resultType="com.casic.missiles.model.customer.CustomerSampleInfo">
SELECT csi.*,sr.real_deliver_time AS "deliverTime"
FROM customer_sample_info csi
JOIN business_order_sample_relation sr ON sr.sample_id = csi.id
WHERE csi.is_del =0
<if test="sampleNo != null and sampleNo !=''">
and csi.sample_no like concat('%', #{sampleNo}, '%')
</if>
<if test="sampleName != null and sampleName !=''">
and csi.sample_name like concat('%', #{sampleName}, '%')
</if>
<if test="orderId != null and orderId !=''">
and sr.order_id = #{orderId}
</if>
ORDER BY csi.create_time DESC
</select>
<select id="listPageByOrder"
resultType="com.casic.missiles.dto.customer.sample.MultiItemSampleListResponse">
SELECT id,sampleName,sampleModel,manufacturingNo,appendixDescn,measureContent,remark,customerName,measurePeriod,
validDeadline,measureLastTime,sampleNo,customerNo,powerVoltage,manufacturer
FROM (
SELECT sample_name AS "sampleName",sample_no AS "sampleNo",sample_model AS "sampleModel",manufacturing_no AS
"manufacturingNo",appendix_descn AS "appendixDescn",remark,customer_name AS "customerName",measure_period AS
"measurePeriod",valid_deadline AS validDeadline,measure_last_time AS "measureLastTime",create_time,id,
measure_content AS "measureContent",customer_no AS "customerNo",power_voltage AS "powerVoltage",manufacturer AS "manufacturer"
FROM customer_sample_info
WHERE is_del=0
<if test="request.sampleNo != null and request.sampleNo !=''">
AND sample_no like concat('%',#{request.sampleNo},'%')
</if>
<if test="request.sampleName != null and request.sampleName !=''">
AND sample_name like concat('%',#{request.sampleName},'%')
</if>
<if test="request.customerId != null and request.customerId !=''">
AND customer_id=#{request.customerId}
</if>
<if test="request.customerNo != null and request.customerNo !=''">
AND customer_no=#{request.customerNo}
</if>
)csi
WHERE id NOT IN
(
SELECT sample_id
FROM business_order_sample_relation bosr
JOIN (
SELECT id,order_code,customer_no
FROM business_order
WHERE is_del=0
<if test="request.customerId != null and request.customerId !=''">
AND customer_id=#{request.customerId}
</if>
<if test="request.customerNo != null and request.customerNo !=''">
AND customer_no=#{request.customerNo}
</if>
<if test="request.orderId!= null and request.orderId !='' ">
AND id ! =#{request.orderId}
</if>
AND (status ='2' OR status ='1' OR status ='' ) <!-- 委托书创建,引入的委托书只能是只能为接收状态-->
)bo ON bo.id=bosr.order_id
)
</select>
<select id="listPageByInterchange"
resultType="com.casic.missiles.dto.customer.sample.MultiItemSampleListResponse">
SELECT orderId,id,sampleName,sampleModel,manufacturingNo,appendixDescn,measureContent,remark,sampleStatus,customerName,measurePeriod,
validDeadline,measureLastTime,sampleNo,orderCode,customerNo
FROM (
SELECT sample_name AS "sampleName",sample_no AS "sampleNo",sample_model AS "sampleModel",manufacturing_no AS
"manufacturingNo",appendix_descn AS "appendixDescn",remark,customer_name AS "customerName",measure_period AS
"measurePeriod",id,
valid_deadline AS validDeadline,measure_last_time AS "measureLastTime",create_time,measure_content AS
"measureContent",customer_no AS "customerNo"
FROM customer_sample_info
WHERE customer_id=#{request.customerId}
<if test="request.sampleNo != null and request.sampleNo !=''">
AND sample_no like concat('%',#{request.sampleNo},'%')
</if>
<if test="request.sampleName != null and request.sampleName !=''">
AND sample_name like concat('%',#{request.sampleName},'%')
</if>
)csi
JOIN (
SELECT sample_status AS "sampleStatus",sample_id as "sampleId",order_id AS "orderId",order_code AS "orderCode"
FROM business_order_sample_relation bosr
JOIN (
SELECT id,order_code
FROM business_order
WHERE customer_id=#{request.customerId}
)bo ON bo.id=bosr.order_id
WHERE interchange_id is null
)bor ON bor.sampleId=csi.id
ORDER BY create_time DESC
</select>
<select id="listPageBySubpackage"
resultType="com.casic.missiles.dto.customer.sample.MultiItemSampleListResponse">
SELECT
orderId,id,sampleName,sampleModel,manufacturingNo,appendixDescn,measureContent,remark,sampleStatus,customerName,measurePeriod,
validDeadline,measureLastTime,sampleNo,orderCode,customerNo
FROM (
SELECT sample_name AS "sampleName",sample_no AS "sampleNo",sample_model AS "sampleModel",manufacturing_no AS
"manufacturingNo",appendix_descn AS "appendixDescn",remark,customer_name AS "customerName",measure_period AS
"measurePeriod",valid_deadline AS validDeadline,measure_last_time AS
"measureLastTime",create_time,id,measure_content AS
"measureContent",
customer_no AS "customerNo"
FROM customer_sample_info
WHERE is_del=0
<if test="request.sampleNo != null and request.sampleNo !=''">
AND sample_no like concat('%',#{request.sampleNo},'%')
</if>
<if test="request.sampleName != null and request.sampleName !=''">
AND sample_name like concat('%',#{request.sampleName},'%')
</if>
<if test="request.customerNo != null and request.customerNo !=''">
AND customer_no=#{request.customerNo}
</if>
)csi
JOIN (
SELECT sample_status AS "sampleStatus",sample_id as "sampleId",order_id AS "orderId",order_code AS "orderCode"
FROM business_order_sample_relation bosr
JOIN (
SELECT id,order_code,customer_no
FROM business_order
WHERE is_del=0
<if test="request.orderCode != null and request.orderCode !=''">
AND order_code=#{request.orderCode}
</if>
<if test="request.customerName != null and request.customerName !=''">
AND customer_name=#{request.customerName}
</if>
<if test="request.startTime != null and request.startTime !=''">
AND create_time <![CDATA[ >= ]]> #{request.startTime}
</if>
<if test="request.endTime != null and request.endTime !=''">
AND create_time <![CDATA[ <= ]]> #{request.endTime}
</if>
AND status='2' <!-- 委托书状态只能为接收状态-->
)bo ON bo.id=bosr.order_id
WHERE (sample_status ='1' OR sample_status ='2') <!-- 样品状态只能为待收入、待分发状态-->
AND sample_id NOT IN <include refid="Sample_Testing"/> <!-- 样品在分包、委托书创建状态不在实验室使用状态-->
AND sample_id NOT IN <include refid="Sample_Outsource"/>
)bor ON bor.sampleId=csi.id
</select>
<select id="listPageBySubpackageCertificate"
resultType="com.casic.missiles.dto.customer.sample.MultiItemSampleListResponse">
SELECT
orderId,id,sampleName,sampleModel,manufacturingNo,appendixDescn,measureContent,remark,sampleStatus,customerName,measurePeriod,
validDeadline,measureLastTime,sampleNo,orderCode,customerNo
FROM (
SELECT sample_name AS "sampleName",sample_no AS "sampleNo",sample_model AS "sampleModel",manufacturing_no AS
"manufacturingNo",appendix_descn AS "appendixDescn",remark,customer_name AS "customerName",measure_period AS
"measurePeriod",id,
valid_deadline AS validDeadline,measure_last_time AS "measureLastTime",create_time,measure_content AS
"measureContent",customer_no AS "customerNo"
FROM customer_sample_info
<if test="request.sampleNo != null and request.sampleNo !=''">
AND sample_no like concat('%',#{request.sampleNo},'%')
</if>
<if test="request.sampleName != null and request.sampleName !=''">
AND sample_name like concat('%',#{request.sampleName},'%')
</if>
)csi
JOIN (
SELECT sample_status AS "sampleStatus",sample_id as "sampleId",order_id AS "orderId",order_code AS "orderCode"
FROM business_order_sample_relation bosr
JOIN (
SELECT id,order_code
FROM business_order
)bo ON bo.id=bosr.order_id
)bor ON bor.sampleId=csi.id
ORDER BY create_time DESC
</select>
<sql id="Sample_Testing">
(
SELECT sample_id
FROM (
SELECT sample_id,measure_status,Max(create_time)
FROM business_lab_executive_info
GROUP BY sample_id,measure_status
) bo
WHERE measure_status= '5'
)
</sql>
<sql id="Sample_Outsource">
(
SELECT bopsr.sample_id
FROM business_outsource_project_sample_relation bopsr
JOIN business_order_sample_relation bosr ON (bopsr.order_id = bosr.order_id AND bopsr.sample_id = bosr.sample_id)
WHERE bosr.sample_status IN ('1','2','3')
)
</sql>
<select id="selectListForReadWriter" resultType="com.casic.missiles.dto.business.dispatch.ReadSampleDTO">
SELECT csi.id, sr.order_id, bo.order_code, bo.customer_id, bo.customer_no, bo.customer_name, csi.sample_no, csi.sample_name, csi.sample_model, csi.manufacturing_no, csi.label_bind
FROM customer_sample_info csi
<!-- 按委托书id和样品id分组取的就是关联表里最新的关联 -->
LEFT JOIN (SELECT order_id, sample_id FROM business_order_sample_relation GROUP BY order_id, sample_id) sr ON sr.sample_id = csi.id
LEFT JOIN business_order bo ON (bo.id = sr.order_id AND bo.is_del = 0)
WHERE csi.is_del = 0
<if test="gunSet != null">
and csi.sample_no in
<foreach collection="gunSet" item="id" index="index" open="(" close=")" separator=",">
#{id}
</foreach>
</if>
<if test="tIds != null">
and csi.label_bind in
<foreach collection="tIds" item="id" index="index" open="(" close=")" separator=",">
#{id}
</foreach>
</if>
<if test="customerId != null and customerId !=''">
AND bo.customer_id = #{customerId}
</if>
AND csi.id NOT IN
(
SELECT sample_id
FROM business_order_sample_relation bosrr
JOIN (
SELECT id
FROM business_order
WHERE is_del = 0
AND (status ='2' OR status ='1' OR status ='' ) <!-- 委托书创建,引入的委托书只能是只能为接收状态-->
)boo ON boo.id = bosrr.order_id
)
ORDER BY csi.create_time DESC
</select>
</mapper>