@ -829,12 +829,10 @@
IFNULL(round(sum(IFNULL(t.sevenToTenNum,0))/sum(lww.total_count)*100,2),'0.00') sevenToTenArriveRate,
sum(IFNULL(t.moreTenNum,0)) moreTenArriveNum,
IFNULL(round(sum(IFNULL(t.moreTenNum,0))/sum(lww.total_count)*100,2),'0.00') moreTenArriveRate
from logpm_warehouse_waybill lww
left join logpm_warehouse_warehouse waw on waw.id = lww.departure_warehouse_id
left join (select ldpl.waybill_id,
from (select ldpl.waybill_id,
sum(ldpl.quantity) totalNum,
sum(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time )) timeSecond,
sum(if(ldpl.create_time < = DATE_ADD( ltad.create_time, INTERVAL IFNULL(lrat.hours_time,0 ) HOUR ),1,0)) onTimeNum,
sum(if(ldpl.create_time < = DATE_ADD( ltad.create_time, INTERVAL IFNULL(lrat.hours_time,#{param.hoursTime} ) HOUR ),1,0)) onTimeNum,
sum(if(ldpl.create_time < = DATE_ADD( ltad.create_time, INTERVAL 24 HOUR ),1,0)) oneNum,
sum(if(DATE_ADD( ltad.create_time, INTERVAL 24 HOUR ) < ldpl.create_time and ldpl.create_time < = DATE_ADD( ltad.create_time, INTERVAL 48 HOUR ),1,0)) twoNum,
sum(if(DATE_ADD( ltad.create_time, INTERVAL 48 HOUR )< ldpl.create_time and ldpl.create_time < = DATE_ADD( ltad.create_time, INTERVAL 72 HOUR ),1,0)) threeNum,
@ -850,24 +848,6 @@
where ldpl.conditions != 3
and ldpl.send_warehouse_id != ldpl.accept_warehouse_id
and ltad.create_time > '2024-10-22 00:00:00'
<if test= "param.brandList != null and param.brandList.size() > 0" >
and ltad.brand in
<foreach collection= "param.brandList" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.departureWarehouseIds != null and param.departureWarehouseIds.size() > 0" >
and ldpl.send_warehouse_id in
<foreach collection= "param.departureWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.destinationWarehouseIds != null and param.destinationWarehouseIds.size() > 0" >
and ldpl.accept_warehouse_id in
<foreach collection= "param.destinationWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.startTime != null " >
and ltad.create_time > = #{param.startTime}
</if>
@ -876,10 +856,10 @@
</if>
and ldpl.warehouse_id = ldpl.accept_warehouse_id
and ldpl.warehouse_id != ldpl.send_warehouse_id
group by ldpl.waybill_id) t on t.waybill_id = lww.id
where lww.waybill_type = 1
and lww.departure_warehouse_id != lww.destination _warehouse_id
and lww.create_time > '2024-10-22 00:00:00'
group by ldpl.waybill_id) t
left join logpm_warehouse_waybill lww on lww.id = t.waybill_id
left join logpm_warehouse_warehouse waw on waw.id = lww.departure _warehouse_id
where 1=1
<if test= "param.businessLineList != null and param.businessLineList.size() > 0" >
and waw.business_line in
<foreach collection= "param.businessLineList" item= "item" open= "(" separator= "," close= ")" >
@ -887,29 +867,23 @@
</foreach>
</if>
<if test= "param.brandList != null and param.brandList.size() > 0" >
and lww .brand in
and ltad .brand in
<foreach collection= "param.brandList" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.departureWarehouseIds != null and param.departureWarehouseIds.size() > 0" >
and lww.departure _warehouse_id in
and ldpl.send _warehouse_id in
<foreach collection= "param.departureWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.destinationWarehouseIds != null and param.destinationWarehouseIds.size() > 0" >
and lww.destination _warehouse_id in
and ldpl.accept _warehouse_id in
<foreach collection= "param.destinationWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.startTime != null " >
and lww.create_time > = #{param.startTime}
</if>
<if test= "param.endTime != null " >
and lww.create_time < = #{param.endTime}
</if>
group by waw.business_line,
lww.departure_warehouse_name,
lww.destination_warehouse_name,
@ -948,12 +922,10 @@
IFNULL(concat(round(sum(IFNULL(t.sevenToTenNum,0))/sum(lww.total_count)*100,2),'%'),'0.00%') sevenToTenArriveRate,
sum(IFNULL(t.moreTenNum,0)) moreTenArriveNum,
IFNULL(concat(round(sum(IFNULL(t.moreTenNum,0))/sum(lww.total_count)*100,2),'%'),'0.00%') moreTenArriveRate
from logpm_warehouse_waybill lww
left join logpm_warehouse_warehouse waw on waw.id = lww.departure_warehouse_id
left join (select ldpl.waybill_id,
from (select ldpl.waybill_id,
sum(ldpl.quantity) totalNum,
sum(TIMESTAMPDIFF(SECOND,ltad.create_time,ldpl.create_time )) timeSecond,
sum(if(ldpl.create_time < = DATE_ADD( ltad.create_time, INTERVAL IFNULL(lrat.hours_time,0 ) HOUR ),1,0)) onTimeNum,
sum(if(ldpl.create_time < = DATE_ADD( ltad.create_time, INTERVAL IFNULL(lrat.hours_time,#{param.hoursTime} ) HOUR ),1,0)) onTimeNum,
sum(if(ldpl.create_time < = DATE_ADD( ltad.create_time, INTERVAL 24 HOUR ),1,0)) oneNum,
sum(if(DATE_ADD( ltad.create_time, INTERVAL 24 HOUR ) < ldpl.create_time and ldpl.create_time < = DATE_ADD( ltad.create_time, INTERVAL 48 HOUR ),1,0)) twoNum,
sum(if(DATE_ADD( ltad.create_time, INTERVAL 48 HOUR )< ldpl.create_time and ldpl.create_time < = DATE_ADD( ltad.create_time, INTERVAL 72 HOUR ),1,0)) threeNum,
@ -969,24 +941,6 @@
where ldpl.conditions != 3
and ldpl.send_warehouse_id != ldpl.accept_warehouse_id
and ltad.create_time > '2024-10-22 00:00:00'
<if test= "param.brandList != null and param.brandList.size() > 0" >
and ltad.brand in
<foreach collection= "param.brandList" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.departureWarehouseIds != null and param.departureWarehouseIds.size() > 0" >
and ldpl.send_warehouse_id in
<foreach collection= "param.departureWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.destinationWarehouseIds != null and param.destinationWarehouseIds.size() > 0" >
and ldpl.accept_warehouse_id in
<foreach collection= "param.destinationWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.startTime != null " >
and ltad.create_time > = #{param.startTime}
</if>
@ -995,10 +949,10 @@
</if>
and ldpl.warehouse_id = ldpl.accept_warehouse_id
and ldpl.warehouse_id != ldpl.send_warehouse_id
group by ldpl.waybill_id) t on t.waybill_id = lww.id
where lww.waybill_type = 1
and lww.departure_warehouse_id != lww.destination _warehouse_id
and lww.create_time > '2024-10-22 00:00:00'
group by ldpl.waybill_id) t
left join logpm_warehouse_waybill lww on lww.id = t.waybill_id
left join logpm_warehouse_warehouse waw on waw.id = lww.departure _warehouse_id
where 1=1
<if test= "param.businessLineList != null and param.businessLineList.size() > 0" >
and waw.business_line in
<foreach collection= "param.businessLineList" item= "item" open= "(" separator= "," close= ")" >
@ -1006,29 +960,23 @@
</foreach>
</if>
<if test= "param.brandList != null and param.brandList.size() > 0" >
and lww .brand in
and ltad .brand in
<foreach collection= "param.brandList" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.departureWarehouseIds != null and param.departureWarehouseIds.size() > 0" >
and lww.departure _warehouse_id in
and ldpl.send _warehouse_id in
<foreach collection= "param.departureWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.destinationWarehouseIds != null and param.destinationWarehouseIds.size() > 0" >
and lww.destination _warehouse_id in
and ldpl.accept _warehouse_id in
<foreach collection= "param.destinationWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.startTime != null " >
and lww.create_time > = #{param.startTime}
</if>
<if test= "param.endTime != null " >
and lww.create_time < = #{param.endTime}
</if>
group by waw.business_line,
lww.departure_warehouse_name,
lww.destination_warehouse_name,
@ -1399,4 +1347,218 @@
lww.brand
</select>
<select id= "orderAllTimePage" resultType= "com.logpm.report.vo.ReportOrderAllTimeVO" >
select ltad.order_code orderCode,
ltad.waybill_no waybillNo,
ltad.brand brand,
lww.shipper shipper,
lww.consignee consignee,
lww.departure_warehouse_name departureWarehouseName,
lww.destination_warehouse_name destinationWarehouseName,
GROUP_CONCAT(DISTINCT ltad.train_number) trainNumber,
GROUP_CONCAT(DISTINCT IFNULL(ltcls.load_code,ltclsm.load_code)) loadCode,
count(ltad.id) totalNum,
min(ltad.create_time) createTime,
min(ldpls.create_time) startIncomingTime,
min(ltcll.start_date) startTime,
min(ldplm.create_time) endIncomingTime,
min(lww.create_time) openTime,
min(lqd.delivery_plan_time) deliveryPlanTime,
min(lqd.sign_time) signTime,
min(lqd.review_time) reviewTime,
min(ltcllm.unload_date) endUnloadTime,
IFNULL(oat.day_time,#{param.dayTime}) dayTime,
IF(min(lqd.sign_time) IS NULL,'否','是') isUploadSignOrder,
IF(min(lqd.sign_time) IS NULL,'否','是') isUploadPut,
CEIL(TIMESTAMPDIFF(SECOND,min(ltad.create_time),min(ldplm.create_time))/3600/24) realdayTime,
CEIL(TIMESTAMPDIFF(SECOND,min(ltad.create_time),min(ldplm.create_time))/3600/24)-IFNULL(oat.day_time,#{param.dayTime}) delayTime,
if(CEIL(TIMESTAMPDIFF(SECOND,min(ltad.create_time),min(ldplm.create_time))/3600/24)-IFNULL(oat.day_time,#{param.dayTime}) > 0,'是','否') delayStatus,
case when sum(if(ldplm.order_package_status='70',1,0))=0 then '未签收'
when count(ltad.id) != sum(if(ldplm.order_package_status='70',1,0)) then '部分签收'
when count(ltad.id) = sum(if(ldplm.order_package_status='70',1,0)) then '已签收'
else '未知' end signStatus,
sum(if(ldplm.order_package_status='70',1,0)) signNum
from logpm_trunkline_advance_detail ltad
left join logpm_warehouse_waybill lww on lww.id = ltad.waybill_id
left join logpm_distribution_parcel_list ldpls on ldpls.warehouse_id = lww.departure_warehouse_id and ldpls.order_package_code = ltad.order_package_code
left join logpm_trunkline_cars_load_scan ltcls on ltcls.scan_code = ldpls.order_package_code and ltcls.warehouse_id = ldpls.warehouse_id
left join logpm_trunkline_cars_load_line ltcll on ltcll.load_id = ltcls.load_id and ltcll.node_id = ltcls.warehouse_id
left join logpm_distribution_parcel_list ldplm on ldplm.warehouse_id = lww.destination_warehouse_id and ldplm.order_package_code = ltad.order_package_code
left join logpm_trunkline_cars_load_scan ltclsm on ltclsm.scan_code = ldplm.order_package_code and ltclsm.unload_node_id = ldplm.warehouse_id
left join logpm_trunkline_cars_load_line ltcllm on ltcllm.load_id = ltclsm.load_id and ltcllm.node_id = ltclsm.unload_node_id
left join logpm_quality_deliver lqd on lqd.order_package_code = ltad.order_package_code and lqd.retention_time is null
left join logpm_reportconfig_order_all oat on oat.departure_warehouse_id = lww.departure_warehouse_id and oat.destination_warehouse_id = lww.destination_warehouse_id and oat.brand = lww.brand
where ltad.waybill_id is not null
and ltad.create_time > '2024-10-22 00:00:00'
and lww.departure_warehouse_id != lww.destination_warehouse_id
<if test= "param.startTime != null " >
and ltad.create_time > = #{param.startTime}
</if>
<if test= "param.endTime != null " >
and ltad.create_time < = #{param.endTime}
</if>
<if test= "param.brandList != null and param.brandList.size() > 0" >
and lww.brand in
<foreach collection= "param.brandList" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.departureWarehouseIds != null and param.departureWarehouseIds.size() > 0" >
and lww.departure_warehouse_id in
<foreach collection= "param.departureWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.destinationWarehouseIds != null and param.destinationWarehouseIds.size() > 0" >
and lww.destination_warehouse_id in
<foreach collection= "param.destinationWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.brand != null and param.brand !='' " >
and ltad.brand = #{param.brand}
</if>
<if test= "param.orderCode != null and param.orderCode !='' " >
and ltad.order_code like concat('%',#{param.orderCode},'%')
</if>
<if test= "param.waybillCode != null and param.waybillCode !='' " >
and ltad.waybill_no like concat('%',#{param.waybillCode},'%')
</if>
<if test= "param.shipper != null and param.shipper !='' " >
and lww.shipper like concat('%',#{param.shipper},'%')
</if>
<if test= "param.consignee != null and param.consignee !='' " >
and lww.consignee like concat('%',#{param.consignee},'%')
</if>
<if test= "param.departureWarehouseName != null and param.departureWarehouseName !='' " >
and lww.departure_warehouse_name like concat('%',#{param.departureWarehouseName},'%')
</if>
<if test= "param.destinationWarehouseName != null and param.destinationWarehouseName !='' " >
and lww.destination_warehouse_name like concat('%',#{param.destinationWarehouseName},'%')
</if>
<if test= "param.trainNumber != null and param.trainNumber !='' " >
and GROUP_CONCAT(DISTINCT ltad.train_number) like concat('%',#{param.trainNumber},'%')
GROUP_CONCAT(DISTINCT IFNULL(ltcls.load_code,ltclsm.load_code)) loadCode,
</if>
<if test= "param.loadCode != null and param.loadCode !='' " >
and GROUP_CONCAT(DISTINCT IFNULL(ltcls.load_code,ltclsm.load_code)) like concat('%',#{param.loadCode},'%')
</if>
group by ltad.order_code,
ltad.waybill_no,
ltad.brand,
lww.shipper,
lww.consignee,
lww.departure_warehouse_name,
lww.destination_warehouse_name,
oat.day_time
</select>
<select id= "orderAllTimeExport" resultType= "com.logpm.report.vo.ReportOrderAllTimeVO" >
select ltad.order_code orderCode,
ltad.waybill_no waybillNo,
ltad.brand brand,
lww.shipper shipper,
lww.consignee consignee,
lww.departure_warehouse_name departureWarehouseName,
lww.destination_warehouse_name destinationWarehouseName,
GROUP_CONCAT(DISTINCT ltad.train_number) trainNumber,
GROUP_CONCAT(DISTINCT IFNULL(ltcls.load_code,ltclsm.load_code)) loadCode,
count(ltad.id) totalNum,
min(ltad.create_time) createTime,
min(ldpls.create_time) startIncomingTime,
min(ltcll.start_date) startTime,
min(ldplm.create_time) endIncomingTime,
min(lww.create_time) openTime,
min(lqd.delivery_plan_time) deliveryPlanTime,
min(lqd.sign_time) signTime,
min(lqd.review_time) reviewTime,
min(ltcllm.unload_date) endUnloadTime,
IFNULL(oat.day_time,#{param.dayTime}) dayTime,
IF(min(lqd.sign_time) IS NULL,'否','是') isUploadSignOrder,
IF(min(lqd.sign_time) IS NULL,'否','是') isUploadPut,
CEIL(TIMESTAMPDIFF(SECOND,min(ltad.create_time),min(ldplm.create_time))/3600/24) realdayTime,
CEIL(TIMESTAMPDIFF(SECOND,min(ltad.create_time),min(ldplm.create_time))/3600/24)-IFNULL(oat.day_time,#{param.dayTime}) delayTime,
if(CEIL(TIMESTAMPDIFF(SECOND,min(ltad.create_time),min(ldplm.create_time))/3600/24)-IFNULL(oat.day_time,#{param.dayTime}) > 0,'是','否') delayStatus,
case when sum(if(ldplm.order_package_status='70',1,0))=0 then '未签收'
when count(ltad.id) != sum(if(ldplm.order_package_status='70',1,0)) then '部分签收'
when count(ltad.id) = sum(if(ldplm.order_package_status='70',1,0)) then '已签收'
else '未知' end signStatus,
sum(if(ldplm.order_package_status='70',1,0)) signNum
from logpm_trunkline_advance_detail ltad
left join logpm_warehouse_waybill lww on lww.id = ltad.waybill_id
left join logpm_distribution_parcel_list ldpls on ldpls.warehouse_id = lww.departure_warehouse_id and ldpls.order_package_code = ltad.order_package_code
left join logpm_trunkline_cars_load_scan ltcls on ltcls.scan_code = ldpls.order_package_code and ltcls.warehouse_id = ldpls.warehouse_id
left join logpm_trunkline_cars_load_line ltcll on ltcll.load_id = ltcls.load_id and ltcll.node_id = ltcls.warehouse_id
left join logpm_distribution_parcel_list ldplm on ldplm.warehouse_id = lww.destination_warehouse_id and ldplm.order_package_code = ltad.order_package_code
left join logpm_trunkline_cars_load_scan ltclsm on ltclsm.scan_code = ldplm.order_package_code and ltclsm.unload_node_id = ldplm.warehouse_id
left join logpm_trunkline_cars_load_line ltcllm on ltcllm.load_id = ltclsm.load_id and ltcllm.node_id = ltclsm.unload_node_id
left join logpm_quality_deliver lqd on lqd.order_package_code = ltad.order_package_code and lqd.retention_time is null
left join logpm_reportconfig_order_all oat on oat.departure_warehouse_id = lww.departure_warehouse_id and oat.destination_warehouse_id = lww.destination_warehouse_id and oat.brand = lww.brand
where ltad.waybill_id is not null
and ltad.create_time > '2024-10-22 00:00:00'
and lww.departure_warehouse_id != lww.destination_warehouse_id
<if test= "param.startTime != null " >
and ltad.create_time > = #{param.startTime}
</if>
<if test= "param.endTime != null " >
and ltad.create_time < = #{param.endTime}
</if>
<if test= "param.brandList != null and param.brandList.size() > 0" >
and lww.brand in
<foreach collection= "param.brandList" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.departureWarehouseIds != null and param.departureWarehouseIds.size() > 0" >
and lww.departure_warehouse_id in
<foreach collection= "param.departureWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.destinationWarehouseIds != null and param.destinationWarehouseIds.size() > 0" >
and lww.destination_warehouse_id in
<foreach collection= "param.destinationWarehouseIds" item= "item" open= "(" separator= "," close= ")" >
#{item}
</foreach>
</if>
<if test= "param.brand != null and param.brand !='' " >
and ltad.brand = #{param.brand}
</if>
<if test= "param.orderCode != null and param.orderCode !='' " >
and ltad.order_code like concat('%',#{param.orderCode},'%')
</if>
<if test= "param.waybillCode != null and param.waybillCode !='' " >
and ltad.waybill_no like concat('%',#{param.waybillCode},'%')
</if>
<if test= "param.shipper != null and param.shipper !='' " >
and lww.shipper like concat('%',#{param.shipper},'%')
</if>
<if test= "param.consignee != null and param.consignee !='' " >
and lww.consignee like concat('%',#{param.consignee},'%')
</if>
<if test= "param.departureWarehouseName != null and param.departureWarehouseName !='' " >
and lww.departure_warehouse_name like concat('%',#{param.departureWarehouseName},'%')
</if>
<if test= "param.destinationWarehouseName != null and param.destinationWarehouseName !='' " >
and lww.destination_warehouse_name like concat('%',#{param.destinationWarehouseName},'%')
</if>
<if test= "param.trainNumber != null and param.trainNumber !='' " >
and GROUP_CONCAT(DISTINCT ltad.train_number) like concat('%',#{param.trainNumber},'%')
GROUP_CONCAT(DISTINCT IFNULL(ltcls.load_code,ltclsm.load_code)) loadCode,
</if>
<if test= "param.loadCode != null and param.loadCode !='' " >
and GROUP_CONCAT(DISTINCT IFNULL(ltcls.load_code,ltclsm.load_code)) like concat('%',#{param.loadCode},'%')
</if>
group by ltad.order_code,
ltad.waybill_no,
ltad.brand,
lww.shipper,
lww.consignee,
lww.departure_warehouse_name,
lww.destination_warehouse_name,
oat.day_time
</select>
</mapper>