From 234b0ac195934b34c06045b2d2ef0f10e239dd8e Mon Sep 17 00:00:00 2001 From: zhuo <2089219845@qq.com> Date: 星期三, 23 四月 2025 00:06:54 +0800 Subject: [PATCH] 系统合并 --- inspect-server/src/main/resources/mapper/InsOrderMapper.xml | 121 ++++++++++++++++++++++----------------- 1 files changed, 68 insertions(+), 53 deletions(-) diff --git a/inspect-server/src/main/resources/mapper/InsOrderMapper.xml b/inspect-server/src/main/resources/mapper/InsOrderMapper.xml index 214e7fa..ad38e37 100644 --- a/inspect-server/src/main/resources/mapper/InsOrderMapper.xml +++ b/inspect-server/src/main/resources/mapper/InsOrderMapper.xml @@ -45,6 +45,61 @@ ip.cable_tag </sql> + <sql id="selectInsOrderExport"> + SELECT + io.*, + isau.user_id assign, + ir.id report_id, + ir.url, + ir.url_s, + sample_counts.sample_num, + CONCAT(ROUND(approved_product_counts.approved_count / total_product_counts.total_count * 100, 2), '%') AS insProgress, + io.sample_view AS sample_name, + GROUP_CONCAT(DISTINCT isa.model SEPARATOR ' ') AS sample_model, + u.name, + testing_name, + case when io.type = 0 then '鏅��' + when io.type = 1 then '浼樺厛' + when io.type = 2 then '绱ф��' + end typeString, + case when io.ins_result = 1 then '鍚堟牸' + when io.ins_result = 0 then '涓嶅悎鏍�' + else '寰呮楠�' end insResultString + FROM + ins_order io + LEFT JOIN + ins_sample isa ON io.id = isa.ins_order_id + LEFT JOIN + ins_sample_user isau ON isau.ins_sample_id = io.id + LEFT JOIN + (SELECT id, ins_order_id, is_ratify, url, url_s FROM ins_report WHERE is_ratify = 1) ir ON io.id = ir.ins_order_id + LEFT JOIN + user u ON io.create_user = u.id + LEFT JOIN + (SELECT ins_order_id, COUNT(*) AS sample_num + FROM ins_sample + WHERE id in(select id1 from (select is2.id id1 ,ip.id from ins_sample is2 left join ins_product ip on is2.id = ip.ins_sample_id where ip.id is not null)s ) + GROUP BY ins_order_id) sample_counts ON io.id = sample_counts.ins_order_id + LEFT JOIN + (SELECT ins_sample.ins_order_id, COUNT(*) AS total_count + FROM ins_product + JOIN ins_sample ON ins_product.ins_sample_id = ins_sample.id + WHERE ins_product.state = 1 + GROUP BY ins_sample.ins_order_id) total_product_counts ON io.id = total_product_counts.ins_order_id + LEFT JOIN + (SELECT ins_sample.ins_order_id, COUNT(*) AS approved_count + FROM ins_product + JOIN ins_sample ON ins_product.ins_sample_id = ins_sample.id + WHERE ins_product.state = 1 AND ins_product.ins_result IS NOT NULL + GROUP BY ins_sample.ins_order_id) approved_product_counts ON io.id = approved_product_counts.ins_order_id + LEFT JOIN (SELECT ins_sample_id, GROUP_CONCAT(DISTINCT uu.name SEPARATOR ',') AS testing_name + FROM ins_sample_user u + LEFT JOIN user uu ON u.user_id = uu.id + WHERE u.state = 0 + GROUP BY ins_sample_id + ORDER BY ins_sample_id) isu ON isu.ins_sample_id = io.id + </sql> + <select id="selectInsOrderPage" resultType="com.ruoyi.inspect.dto.SampleOrderDto"> select * from ( @@ -356,59 +411,7 @@ <!-- 鏌ヨ妫�楠屽崟鏁版嵁 --> <select id="rawAllInsOrderExport" resultType="com.ruoyi.inspect.dto.SampleOrderDto"> select * - from ( - SELECT - io.*, - isau.user_id assign, - ir.id report_id, - ir.url, - ir.url_s, - sample_counts.sample_num, - CONCAT(ROUND(approved_product_counts.approved_count / total_product_counts.total_count * 100, 2), '%') AS insProgress, - io.sample_view AS sample_name, - GROUP_CONCAT(DISTINCT isa.model SEPARATOR ' ') AS sample_model, - u.name, - testing_name, - case when io.type = 0 then '鏅��' - when io.type = 1 then '浼樺厛' - when io.type = 2 then '绱ф��' - end typeString, - case when io.ins_result = 1 then '鍚堟牸' - when io.ins_result = 0 then '涓嶅悎鏍�' - else '寰呮楠�' end insResultString - FROM - ins_order io - LEFT JOIN - ins_sample isa ON io.id = isa.ins_order_id - LEFT JOIN - ins_sample_user isau ON isau.ins_sample_id = io.id - LEFT JOIN - (SELECT id, ins_order_id, is_ratify, url, url_s FROM ins_report WHERE is_ratify = 1) ir ON io.id = ir.ins_order_id - LEFT JOIN - user u ON io.create_user = u.id - LEFT JOIN - (SELECT ins_order_id, COUNT(*) AS sample_num - FROM ins_sample - WHERE id in(select id1 from (select is2.id id1 ,ip.id from ins_sample is2 left join ins_product ip on is2.id = ip.ins_sample_id where ip.id is not null)s ) - GROUP BY ins_order_id) sample_counts ON io.id = sample_counts.ins_order_id - LEFT JOIN - (SELECT ins_sample.ins_order_id, COUNT(*) AS total_count - FROM ins_product - JOIN ins_sample ON ins_product.ins_sample_id = ins_sample.id - WHERE ins_product.state = 1 - GROUP BY ins_sample.ins_order_id) total_product_counts ON io.id = total_product_counts.ins_order_id - LEFT JOIN - (SELECT ins_sample.ins_order_id, COUNT(*) AS approved_count - FROM ins_product - JOIN ins_sample ON ins_product.ins_sample_id = ins_sample.id - WHERE ins_product.state = 1 AND ins_product.ins_result IS NOT NULL - GROUP BY ins_sample.ins_order_id) approved_product_counts ON io.id = approved_product_counts.ins_order_id - LEFT JOIN (SELECT ins_sample_id, GROUP_CONCAT(DISTINCT uu.name SEPARATOR ',') AS testing_name - FROM ins_sample_user u - LEFT JOIN user uu ON u.user_id = uu.id - WHERE u.state = 0 - GROUP BY ins_sample_id - ORDER BY ins_sample_id) isu ON isu.ins_sample_id = io.id + from ( <include refid="selectInsOrderExport"/> where (io.ifs_inventory_id IS NULL OR TRIM(io.ifs_inventory_id) = '') <if test="isOrderAll != null and isOrderAll != ''"> AND io.state in (1, 4) @@ -440,4 +443,16 @@ left join ins_sample is2 on is2.ins_order_id = io.id where is2.id = #{insSampleId} </select> + + <!-- 鏍规嵁璁㈠崟id鏌ヨ璁㈠崟瀵煎嚭淇℃伅 --> + <select id="getInsOrderExportByIds" resultType="com.ruoyi.inspect.dto.SampleOrderDto"> + <include refid="selectInsOrderExport"/> + where (io.ifs_inventory_id IS NULL OR TRIM(io.ifs_inventory_id) = '') + and io.id in + <foreach item="id" collection="orderIds" open="(" separator="," close=")"> + #{id} + </foreach> + GROUP BY io.id,type + order by type desc,io.id desc + </select> </mapper> -- Gitblit v1.9.3