case when round(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time)/3600,1)<=IFNULL(lrat.hours_time,#{param.hoursTime}) then '0'
when round(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time)/3600,1)>IFNULL(lrat.hours_time,#{param.hoursTime}) then '1'
else '未知' end isOverTime
from logpm_trunkline_advance_detail ltad
left join logpm_trunkline_advance lta on lta.id = ltad.advance_id
left join logpm_warehouse_waybill lww on lww.id = ltad.waybill_id
left join logpm_warehouse_warehouse waw on waw.id = lww.departure_warehouse_id
left join logpm_distribution_parcel_list ldpl on ltad.order_package_code = ldpl.order_package_code and ldpl.warehouse_id = lww.destination_warehouse_id
left join logpm_reportconfig_all_trunkline lrat on lrat.departure_warehouse_id = ldpl.send_warehouse_id and lrat.destination_warehouse_id = ldpl.accept_warehouse_id and lrat.is_deleted=0
where 1=1
and lww.departure_warehouse_id != lww.destination_warehouse_id
and waw.business_line = #{param.businessLine}
and lww.departure_warehouse_id = #{param.departureWarehouseId}
and lww.destination_warehouse_id = #{param.destinationWarehouseId}
and lww.brand = #{param.brand}
<iftest="param.startTime != null">
and ltad.create_time >= #{param.startTime}
</if>
<iftest="param.endTime != null">
and ltad.create_time <= #{param.endTime}
</if>
<iftest="param.orderCode != null and param.orderCode != ''">
and ltad.order_code like concat('%',#{param.orderCode},'%')
</if>
<iftest="param.waybillNo != null and param.waybillNo != ''">
and ltad.waybill_no like concat('%',#{param.waybillNo},'%')
</if>
<iftest="param.departureWarehouseName != null and param.departureWarehouseName != ''">
and lww.departure_warehouse_name like concat('%',#{param.departureWarehouseName},'%')
</if>
<iftest="param.destinationWarehouseName != null and param.destinationWarehouseName != ''">
and lww.destination_warehouse_name like concat('%',#{param.destinationWarehouseName},'%')
</if>
<iftest="param.orderPackageCode != null and param.orderPackageCode != ''">
and ltad.order_package_code like concat('%',#{param.orderPackageCode},'%')
</if>
<iftest="param.serviceNum != null and param.serviceNum != ''">
and ltad.service_num like concat('%',#{param.serviceNum},'%')
</if>
<iftest="param.trainNumber != null and param.trainNumber != ''">
and ltad.train_number like concat('%',#{param.trainNumber},'%')
</if>
<iftest="param.isDesIncomging != null">
and IF(ldpl.id IS NULL,0,1) = #{param.isDesIncomging}
</if>
<iftest="param.isOverTime != null and param.isOverTime ==0">
and round(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time)/3600,1)<=IFNULL(lrat.hours_time,#{param.hoursTime})
</if>
<iftest="param.isOverTime != null and param.isOverTime ==1">
and round(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time)/3600,1)>IFNULL(lrat.hours_time,#{param.hoursTime})
</if>
<iftest="param.allTrunklineTimeDetailType != null and param.allTrunklineTimeDetailType ==2">
and ldpl.id IS NOT NULL
</if>
<iftest="param.allTrunklineTimeDetailType != null and param.allTrunklineTimeDetailType ==3">
and ldpl.id IS NULL
</if>
<iftest="param.allTrunklineTimeDetailType != null and param.allTrunklineTimeDetailType ==4">
and ldpl.id IS NOT NULL
and round(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time)/3600,1)<=IFNULL(lrat.hours_time,#{param.hoursTime})
case when round(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time)/3600,1)<=IFNULL(lrat.hours_time,#{param.hoursTime}) then '未超时'
when round(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time)/3600,1)>IFNULL(lrat.hours_time,#{param.hoursTime}) then '超时'
else '未知' end isOverTime
from logpm_trunkline_advance_detail ltad
left join logpm_trunkline_advance lta on lta.id = ltad.advance_id
left join logpm_warehouse_waybill lww on lww.id = ltad.waybill_id
left join logpm_warehouse_warehouse waw on waw.id = lww.departure_warehouse_id
left join logpm_distribution_parcel_list ldpl on ltad.order_package_code = ldpl.order_package_code and ldpl.warehouse_id = lww.destination_warehouse_id
left join logpm_reportconfig_all_trunkline lrat on lrat.departure_warehouse_id = ldpl.send_warehouse_id and lrat.destination_warehouse_id = ldpl.accept_warehouse_id and lrat.is_deleted=0
where 1=1
and lww.departure_warehouse_id != lww.destination_warehouse_id
and waw.business_line = #{param.businessLine}
and lww.departure_warehouse_id = #{param.departureWarehouseId}
and lww.destination_warehouse_id = #{param.destinationWarehouseId}
and lww.brand = #{param.brand}
<iftest="param.startTime != null">
and ltad.create_time >= #{param.startTime}
</if>
<iftest="param.endTime != null">
and ltad.create_time <= #{param.endTime}
</if>
<iftest="param.orderCode != null and param.orderCode != ''">
and ltad.order_code like concat('%',#{param.orderCode},'%')
</if>
<iftest="param.waybillNo != null and param.waybillNo != ''">
and ltad.waybill_no like concat('%',#{param.waybillNo},'%')
</if>
<iftest="param.departureWarehouseName != null and param.departureWarehouseName != ''">
and lww.departure_warehouse_name like concat('%',#{param.departureWarehouseName},'%')
</if>
<iftest="param.destinationWarehouseName != null and param.destinationWarehouseName != ''">
and lww.destination_warehouse_name like concat('%',#{param.destinationWarehouseName},'%')
</if>
<iftest="param.orderPackageCode != null and param.orderPackageCode != ''">
and ltad.order_package_code like concat('%',#{param.orderPackageCode},'%')
</if>
<iftest="param.serviceNum != null and param.serviceNum != ''">
and ltad.service_num like concat('%',#{param.serviceNum},'%')
</if>
<iftest="param.trainNumber != null and param.trainNumber != ''">
and ltad.train_number like concat('%',#{param.trainNumber},'%')
</if>
<iftest="param.isDesIncomging != null">
and IF(ldpl.id IS NULL,0,1) = #{param.isDesIncomging}
</if>
<iftest="param.isOverTime != null and param.isOverTime ==0">
and round(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time)/3600,1)<=IFNULL(lrat.hours_time,#{param.hoursTime})
</if>
<iftest="param.isOverTime != null and param.isOverTime ==1">
and round(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time)/3600,1)>IFNULL(lrat.hours_time,#{param.hoursTime})
</if>
<iftest="param.allTrunklineTimeDetailType != null and param.allTrunklineTimeDetailType ==2">
and ldpl.id IS NOT NULL
</if>
<iftest="param.allTrunklineTimeDetailType != null and param.allTrunklineTimeDetailType ==3">
and ldpl.id IS NULL
</if>
<iftest="param.allTrunklineTimeDetailType != null and param.allTrunklineTimeDetailType ==4">
and ldpl.id IS NOT NULL
and round(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time)/3600,1)<=IFNULL(lrat.hours_time,#{param.hoursTime})
case when round(TIMESTAMPDIFF(SECOND,ltad.incoming_time,IFNULL(ltcll.start_date,NOW()))/3600,1)<=#{param.hoursTime} then '0'
when round(TIMESTAMPDIFF(SECOND,ltad.incoming_time,IFNULL(ltcll.start_date,NOW()))/3600,1)>#{param.hoursTime} then '1'
else '未知' end isOverTime
from logpm_trunkline_advance_detail ltad
left join logpm_trunkline_advance lta on lta.id = ltad.advance_id
left join logpm_warehouse_waybill lww on lww.id = ltad.waybill_id
left join logpm_warehouse_warehouse waw on waw.id = ltad.warehouse_id
left join logpm_trunkline_cars_load_scan ltcls on ltcls.scan_code = ltad.order_package_code and ltcls.warehouse_id = ltad.warehouse_id and ltcls.type = 1
left join logpm_trunkline_cars_load_line ltcll on ltcll.load_id = ltcls.load_id and ltcll.node_id = ltcls.warehouse_id
where ltad.create_time > '2024-10-22 00:00:00'
and lww.departure_warehouse_id != lww.destination_warehouse_id
and waw.business_line is not null
and waw.business_line = #{param.businessLine}
and lww.departure_warehouse_id = #{param.departureWarehouseId}
and lww.destination_warehouse_id = #{param.destinationWarehouseId}
and lww.brand = #{param.brand}
<iftest="param.startTime != null">
and ltad.create_time >= #{param.startTime}
</if>
<iftest="param.endTime != null">
and ltad.create_time <= #{param.endTime}
</if>
<iftest="param.orderCode != null and param.orderCode != ''">
and ltad.order_code like concat('%',#{param.orderCode},'%')
</if>
<iftest="param.waybillNo != null and param.waybillNo != ''">
and ltad.waybill_no like concat('%',#{param.waybillNo},'%')
</if>
<iftest="param.nowWarehouseName != null and param.nowWarehouseName != ''">
and ltad.now_warehouse_name like concat('%',#{param.nowWarehouseName},'%')
</if>
<iftest="param.departureWarehouseName != null and param.departureWarehouseName != ''">
and lww.departure_warehouse_name like concat('%',#{param.departureWarehouseName},'%')
</if>
<iftest="param.destinationWarehouseName != null and param.destinationWarehouseName != ''">
and lww.destination_warehouse_name like concat('%',#{param.destinationWarehouseName},'%')
</if>
<iftest="param.orderPackageCode != null and param.orderPackageCode != ''">
and ltad.order_package_code like concat('%',#{param.orderPackageCode},'%')
</if>
<iftest="param.serviceNum != null and param.serviceNum != ''">
and ltad.service_num like concat('%',#{param.serviceNum},'%')
</if>
<iftest="param.trainNumber != null and param.trainNumber != ''">
and ltad.train_number like concat('%',#{param.trainNumber},'%')
</if>
<iftest="param.isDesIncomging != null">
and if(ltcll.start_date is null,0,1) = #{param.isDesIncomging}
</if>
<iftest="param.isOverTime != null and param.isOverTime ==0">
and round(TIMESTAMPDIFF(SECOND,ltad.incoming_time,IFNULL(ltcll.start_date,NOW()))/3600,1)<=#{param.hoursTime}
</if>
<iftest="param.isOverTime != null and param.isOverTime ==1">
and round(TIMESTAMPDIFF(SECOND,ltad.incoming_time,IFNULL(ltcll.start_date,NOW()))/3600,1)>#{param.hoursTime}
</if>
<iftest="param.startDetailType != null and param.startDetailType ==1">
and ltad.waybill_id is not null
</if>
<iftest="param.startDetailType != null and param.startDetailType ==2">
and ltcls.id is not null
</if>
<iftest="param.startDetailType != null and param.startDetailType ==3">
and ltcls.id is null
</if>
<iftest="param.startDetailType != null and param.startDetailType ==4">
and ltcls.id is null
and now() <= DATE_ADD( ltad.create_time, INTERVAL #{param.hoursTime} HOUR )
case when round(TIMESTAMPDIFF(SECOND,ltad.incoming_time,IFNULL(ltcll.start_date,NOW()))/3600,1)<=#{param.hoursTime} then '未超时'
when round(TIMESTAMPDIFF(SECOND,ltad.incoming_time,IFNULL(ltcll.start_date,NOW()))/3600,1)>#{param.hoursTime} then '超时'
else '未知' end isOverTime
from logpm_trunkline_advance_detail ltad
left join logpm_trunkline_advance lta on lta.id = ltad.advance_id
left join logpm_warehouse_waybill lww on lww.id = ltad.waybill_id
left join logpm_warehouse_warehouse waw on waw.id = ltad.warehouse_id
left join logpm_trunkline_cars_load_scan ltcls on ltcls.scan_code = ltad.order_package_code and ltcls.warehouse_id = ltad.warehouse_id and ltcls.type = 1
left join logpm_trunkline_cars_load_line ltcll on ltcll.load_id = ltcls.load_id and ltcll.node_id = ltcls.warehouse_id
where ltad.create_time > '2024-10-22 00:00:00'
and lww.departure_warehouse_id != lww.destination_warehouse_id
and waw.business_line is not null
and waw.business_line = #{param.businessLine}
and lww.departure_warehouse_id = #{param.departureWarehouseId}
and lww.destination_warehouse_id = #{param.destinationWarehouseId}
and lww.brand = #{param.brand}
<iftest="param.startTime != null">
and ltad.create_time >= #{param.startTime}
</if>
<iftest="param.endTime != null">
and ltad.create_time <= #{param.endTime}
</if>
<iftest="param.orderCode != null and param.orderCode != ''">
and ltad.order_code like concat('%',#{param.orderCode},'%')
</if>
<iftest="param.waybillNo != null and param.waybillNo != ''">
and ltad.waybill_no like concat('%',#{param.waybillNo},'%')
</if>
<iftest="param.nowWarehouseName != null and param.nowWarehouseName != ''">
and ltad.now_warehouse_name like concat('%',#{param.nowWarehouseName},'%')
</if>
<iftest="param.departureWarehouseName != null and param.departureWarehouseName != ''">
and lww.departure_warehouse_name like concat('%',#{param.departureWarehouseName},'%')
</if>
<iftest="param.destinationWarehouseName != null and param.destinationWarehouseName != ''">
and lww.destination_warehouse_name like concat('%',#{param.destinationWarehouseName},'%')
</if>
<iftest="param.orderPackageCode != null and param.orderPackageCode != ''">
and ltad.order_package_code like concat('%',#{param.orderPackageCode},'%')
</if>
<iftest="param.serviceNum != null and param.serviceNum != ''">
and ltad.service_num like concat('%',#{param.serviceNum},'%')
</if>
<iftest="param.trainNumber != null and param.trainNumber != ''">
and ltad.train_number like concat('%',#{param.trainNumber},'%')
</if>
<iftest="param.isDesIncomging != null">
and if(ltcll.start_date is null,0,1) = #{param.isDesIncomging}
</if>
<iftest="param.isOverTime != null and param.isOverTime ==0">
and round(TIMESTAMPDIFF(SECOND,ltad.incoming_time,IFNULL(ltcll.start_date,NOW()))/3600,1)<=#{param.hoursTime}
</if>
<iftest="param.isOverTime != null and param.isOverTime ==1">
and round(TIMESTAMPDIFF(SECOND,ltad.incoming_time,IFNULL(ltcll.start_date,NOW()))/3600,1)>#{param.hoursTime}
</if>
<iftest="param.startDetailType != null and param.startDetailType ==1">
and ltad.waybill_id is not null
</if>
<iftest="param.startDetailType != null and param.startDetailType ==2">
and ltcls.id is not null
</if>
<iftest="param.startDetailType != null and param.startDetailType ==3">
and ltcls.id is null
</if>
<iftest="param.startDetailType != null and param.startDetailType ==4">
and ltcls.id is null
and now() <= DATE_ADD( ltad.create_time, INTERVAL #{param.hoursTime} HOUR )
case when round(TIMESTAMPDIFF(SECOND,ldpl.create_time,IFNULL(ltcll.start_date,NOW()))/3600,1)<=72 then '未超时'
when round(TIMESTAMPDIFF(SECOND,ldpl.create_time,IFNULL(ltcll.start_date,NOW()))/3600,1)>72 then '超时'
else '未知' end isOverTime
from logpm_distribution_parcel_list ldpl
left join logpm_trunkline_advance lta on lta.id = ldpl.advance_id
left join logpm_warehouse_warehouse waw on waw.id = ldpl.warehouse_id
left join logpm_trunkline_cars_load_scan ltcls on ltcls.scan_code = ldpl.order_package_code and ltcls.warehouse_id = ldpl.warehouse_id and ltcls.type = 1
left join logpm_trunkline_cars_load_line ltcll on ltcll.load_id = ltcls.load_id and ltcll.node_id = ltcls.warehouse_id
where ldpl.is_transfer = 1
and ldpl.create_time > '2024-10-22 00:00:00'
and ldpl.conditions != 3
and ldpl.waybill_id is not null
and ldpl.warehouse_id != ldpl.send_warehouse_id
and ldpl.warehouse_id != ldpl.accept_warehouse_id
and waw.business_line = #{param.businessLine}
and ldpl.send_warehouse_id = #{param.departureWarehouseId}
and ldpl.warehouse_id = #{param.warehouseId}
and ldpl.accept_warehouse_id = #{param.destinationWarehouseId}
and ldpl.brand_name = #{param.brand}
<iftest="param.startTime != null">
and ldpl.create_time >= #{param.startTime}
</if>
<iftest="param.endTime != null">
and ldpl.create_time <= #{param.endTime}
</if>
<iftest="param.orderCode != null and param.orderCode != ''">
and ldpl.order_code like concat('%',#{param.orderCode},'%')
</if>
<iftest="param.waybillNo != null and param.waybillNo != ''">
and ldpl.waybill_number like concat('%',#{param.waybillNo},'%')
</if>
<iftest="param.departureWarehouseName != null and param.departureWarehouseName != ''">
and ldpl.send_warehouse_name like concat('%',#{param.departureWarehouseName},'%')
</if>
<iftest="param.destinationWarehouseName != null and param.destinationWarehouseName != ''">
and ldpl.accept_warehouse_name like concat('%',#{param.destinationWarehouseName},'%')
</if>
<iftest="param.orderPackageCode != null and param.orderPackageCode != ''">
and ldpl.order_package_code like concat('%',#{param.orderPackageCode},'%')
</if>
<iftest="param.serviceNum != null and param.serviceNum != ''">
and ldpl.service_number like concat('%',#{param.serviceNum},'%')
</if>
<iftest="param.trainNumber != null and param.trainNumber != ''">
and ldpl.train_number like concat('%',#{param.trainNumber},'%')
</if>
<iftest="param.isDesIncomging != null">
and if(ltcll.start_date is null,0,1) = #{param.isDesIncomging}
</if>
<iftest="param.isOverTime != null and param.isOverTime ==0">
and round(TIMESTAMPDIFF(SECOND,ldpl.create_time,IFNULL(ltcll.start_date,NOW()))/3600,1)<=#{param.hoursTime}
</if>
<iftest="param.isOverTime != null and param.isOverTime ==1">
and round(TIMESTAMPDIFF(SECOND,ldpl.create_time,IFNULL(ltcll.start_date,NOW()))/3600,1)>#{param.hoursTime}
</if>
<iftest="param.startDetailType != null and param.startDetailType ==2">
and ltcls.id is not null
</if>
<iftest="param.startDetailType != null and param.startDetailType ==3">
and ltcls.id is null
</if>
<iftest="param.startDetailType != null and param.startDetailType ==3">
and ltcls.id is null
and now() <= DATE_ADD( ldpl.create_time, INTERVAL #{param.hoursTime} HOUR )
case when round(TIMESTAMPDIFF(SECOND,ldpl.create_time,IFNULL(ltcll.start_date,NOW()))/3600,1)<=72 then '未超时'
when round(TIMESTAMPDIFF(SECOND,ldpl.create_time,IFNULL(ltcll.start_date,NOW()))/3600,1)>72 then '超时'
else '未知' end isOverTime
from logpm_distribution_parcel_list ldpl
left join logpm_trunkline_advance lta on lta.id = ldpl.advance_id
left join logpm_warehouse_warehouse waw on waw.id = ldpl.warehouse_id
left join logpm_trunkline_cars_load_scan ltcls on ltcls.scan_code = ldpl.order_package_code and ltcls.warehouse_id = ldpl.warehouse_id and ltcls.type = 1
left join logpm_trunkline_cars_load_line ltcll on ltcll.load_id = ltcls.load_id and ltcll.node_id = ltcls.warehouse_id
where ldpl.is_transfer = 1
and ldpl.create_time > '2024-10-22 00:00:00'
and ldpl.conditions != 3
and ldpl.waybill_id is not null
and ldpl.warehouse_id != ldpl.send_warehouse_id
and ldpl.warehouse_id != ldpl.accept_warehouse_id
and waw.business_line = #{param.businessLine}
and ldpl.send_warehouse_id = #{param.departureWarehouseId}
and ldpl.warehouse_id = #{param.warehouseId}
and ldpl.accept_warehouse_id = #{param.destinationWarehouseId}
and ldpl.brand_name = #{param.brand}
<iftest="param.startTime != null">
and ldpl.create_time >= #{param.startTime}
</if>
<iftest="param.endTime != null">
and ldpl.create_time <= #{param.endTime}
</if>
<iftest="param.orderCode != null and param.orderCode != ''">
and ldpl.order_code like concat('%',#{param.orderCode},'%')
</if>
<iftest="param.waybillNo != null and param.waybillNo != ''">
and ldpl.waybill_number like concat('%',#{param.waybillNo},'%')
</if>
<iftest="param.departureWarehouseName != null and param.departureWarehouseName != ''">
and ldpl.send_warehouse_name like concat('%',#{param.departureWarehouseName},'%')
</if>
<iftest="param.destinationWarehouseName != null and param.destinationWarehouseName != ''">
and ldpl.accept_warehouse_name like concat('%',#{param.destinationWarehouseName},'%')
</if>
<iftest="param.orderPackageCode != null and param.orderPackageCode != ''">
and ldpl.order_package_code like concat('%',#{param.orderPackageCode},'%')
</if>
<iftest="param.serviceNum != null and param.serviceNum != ''">
and ldpl.service_number like concat('%',#{param.serviceNum},'%')
</if>
<iftest="param.trainNumber != null and param.trainNumber != ''">
and ldpl.train_number like concat('%',#{param.trainNumber},'%')
</if>
<iftest="param.isDesIncomging != null">
and if(ltcll.start_date is null,0,1) = #{param.isDesIncomging}
</if>
<iftest="param.isOverTime != null and param.isOverTime ==0">
and round(TIMESTAMPDIFF(SECOND,ldpl.create_time,IFNULL(ltcll.start_date,NOW()))/3600,1)<=#{param.hoursTime}
</if>
<iftest="param.isOverTime != null and param.isOverTime ==1">
and round(TIMESTAMPDIFF(SECOND,ldpl.create_time,IFNULL(ltcll.start_date,NOW()))/3600,1)>#{param.hoursTime}
</if>
<iftest="param.startDetailType != null and param.startDetailType ==2">
and ltcls.id is not null
</if>
<iftest="param.startDetailType != null and param.startDetailType ==3">
and ltcls.id is null
</if>
<iftest="param.startDetailType != null and param.startDetailType ==3">
and ltcls.id is null
and now() <= DATE_ADD( ldpl.create_time, INTERVAL #{param.hoursTime} HOUR )