From 4f45f29e6b53f4c01b414409c5000ff4e212b3d9 Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期五, 05 六月 2026 13:36:54 +0800
Subject: [PATCH] 增加eip

---
 report-server/src/main/resources/mapper/WorkStatisticsMapper.xml |   87 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 87 insertions(+), 0 deletions(-)

diff --git a/report-server/src/main/resources/mapper/WorkStatisticsMapper.xml b/report-server/src/main/resources/mapper/WorkStatisticsMapper.xml
new file mode 100644
index 0000000..80acaae
--- /dev/null
+++ b/report-server/src/main/resources/mapper/WorkStatisticsMapper.xml
@@ -0,0 +1,87 @@
+<?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.ruoyi.report.mapper.WorkStatisticsMapper">
+
+    <!-- 鎸変汉鍛樼粺璁� -->
+    <select id="getByUser" resultType="com.ruoyi.report.vo.WorkStatisticsVo">
+        SELECT
+            u.id AS userId,
+            u.name AS userName,
+            d.dept_name AS deptName,
+            COUNT(DISTINCT s.id) AS sampleCount,
+            COUNT(p.id) AS itemCount,
+            SUM(CASE WHEN o.ins_time IS NOT NULL AND o.ins_time &lt;= o.appointed THEN 1 ELSE 0 END) AS timelyCount,
+            SUM(CASE WHEN o.ins_time IS NOT NULL AND o.ins_time > o.appointed THEN 1 ELSE 0 END) AS overdueCount
+        FROM ins_product p
+        LEFT JOIN ins_sample s ON p.ins_sample_id = s.id
+        LEFT JOIN ins_order o ON s.ins_order_id = o.id
+        LEFT JOIN ins_product_user pu ON p.id = pu.ins_product_id
+        LEFT JOIN user u ON pu.create_user = u.id
+        LEFT JOIN sys_dept d ON u.dept_id = d.dept_id
+        WHERE p.ins_result IS NOT NULL
+        <if test="dto.startTime != null and dto.startTime != ''">
+            AND o.ins_time >= #{dto.startTime}
+        </if>
+        <if test="dto.endTime != null and dto.endTime != ''">
+            AND o.ins_time &lt;= #{dto.endTime}
+        </if>
+        <if test="dto.userId != null">
+            AND pu.create_user = #{dto.userId}
+        </if>
+        <if test="dto.deptId != null">
+            AND u.dept_id = #{dto.deptId}
+        </if>
+        GROUP BY u.id
+        ORDER BY sampleCount DESC
+    </select>
+
+    <!-- 鍙婃椂鐜囩粺璁� -->
+    <select id="getTimelyRate" resultType="java.util.Map">
+        SELECT
+            u.name AS userName,
+            COUNT(*) AS totalCount,
+            SUM(CASE WHEN o.ins_time IS NOT NULL AND o.ins_time &lt;= o.appointed THEN 1 ELSE 0 END) AS timelyCount,
+            ROUND(SUM(CASE WHEN o.ins_time IS NOT NULL AND o.ins_time &lt;= o.appointed THEN 1 ELSE 0 END) * 100.0 / COUNT(*), 2) AS timelyRate
+        FROM ins_order o
+        LEFT JOIN ins_sample s ON o.id = s.ins_order_id
+        LEFT JOIN ins_product p ON s.id = p.ins_sample_id
+        LEFT JOIN user u ON o.prepare_user_id = u.id
+        WHERE o.ins_state = 5
+        <if test="dto.startTime != null and dto.startTime != ''">
+            AND o.ins_time >= #{dto.startTime}
+        </if>
+        <if test="dto.endTime != null and dto.endTime != ''">
+            AND o.ins_time &lt;= #{dto.endTime}
+        </if>
+        <if test="dto.deptId != null">
+            AND u.dept_id = #{dto.deptId}
+        </if>
+        GROUP BY u.id
+        ORDER BY timelyRate DESC
+    </select>
+
+    <!-- 宸ヤ綔瓒嬪娍鍥� -->
+    <select id="getTrend" resultType="java.util.Map">
+        SELECT
+            DATE_FORMAT(o.ins_time, '%Y-%m-%d') AS date,
+            COUNT(DISTINCT s.id) AS sampleCount,
+            COUNT(p.id) AS itemCount
+        FROM ins_product p
+        LEFT JOIN ins_sample s ON p.ins_sample_id = s.id
+        LEFT JOIN ins_order o ON s.ins_order_id = o.id
+        LEFT JOIN ins_product_user pu ON p.id = pu.ins_product_id
+        WHERE p.ins_result IS NOT NULL
+        <if test="dto.startTime != null and dto.startTime != ''">
+            AND o.ins_time >= #{dto.startTime}
+        </if>
+        <if test="dto.endTime != null and dto.endTime != ''">
+            AND o.ins_time &lt;= #{dto.endTime}
+        </if>
+        <if test="dto.userId != null">
+            AND pu.create_user = #{dto.userId}
+        </if>
+        GROUP BY DATE_FORMAT(o.ins_time, '%Y-%m-%d')
+        ORDER BY date ASC
+    </select>
+
+</mapper>
\ No newline at end of file

--
Gitblit v1.9.3