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/DashboardMapper.xml |  164 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 164 insertions(+), 0 deletions(-)

diff --git a/report-server/src/main/resources/mapper/DashboardMapper.xml b/report-server/src/main/resources/mapper/DashboardMapper.xml
new file mode 100644
index 0000000..93e7eef
--- /dev/null
+++ b/report-server/src/main/resources/mapper/DashboardMapper.xml
@@ -0,0 +1,164 @@
+<?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.DashboardMapper">
+
+    <!-- 鑾峰彇寰呴鏍峰搧鏁� -->
+    <select id="getWaitReceive" resultType="java.lang.Integer">
+        SELECT COUNT(*) FROM ins_sample WHERE ins_state = 0
+    </select>
+
+    <!-- 鑾峰彇寰呮鏍峰搧鏁� -->
+    <select id="getWaitInspection" resultType="java.lang.Integer">
+        SELECT COUNT(*) FROM ins_order WHERE ins_state = 0
+    </select>
+
+    <!-- 鑾峰彇寰呭鏍告牱鍝佹暟 -->
+    <select id="getWaitAudit" resultType="java.lang.Integer">
+        SELECT COUNT(*) FROM ins_order WHERE ins_state = 3
+    </select>
+
+    <!-- 鑾峰彇寰呯紪鍒舵姤鍛婃暟 -->
+    <select id="getWaitReport" resultType="java.lang.Integer">
+        SELECT COUNT(*) FROM ins_report WHERE state = 0
+    </select>
+
+    <!-- 浠婃棩鏂板鏍峰搧 -->
+    <select id="getTodayNewSample" resultType="java.lang.Integer">
+        SELECT COUNT(*) FROM ins_sample
+        WHERE DATE(create_time) = CURDATE()
+    </select>
+
+    <!-- 浠婃棩瀹屾垚鏍峰搧 -->
+    <select id="getTodayFinished" resultType="java.lang.Integer">
+        SELECT COUNT(*) FROM ins_order
+        WHERE ins_state = 5 AND DATE(ins_time) = CURDATE()
+    </select>
+
+    <!-- 鍘嗗彶15澶╂暟鎹� -->
+    <select id="getHistoryDays" resultType="com.ruoyi.report.vo.TaskCalendarVo">
+        SELECT
+            DATE_FORMAT(DATE_SUB(CURDATE(), INTERVAL n DAY), '%Y-%m-%d') AS date,
+            COUNT(DISTINCT s.id) AS sampleCount,
+            SUM(CASE WHEN o.ins_state = 5 THEN 1 ELSE 0 END) AS finishedCount,
+            SUM(CASE WHEN o.ins_state IN (0,1,2,3) THEN 1 ELSE 0 END) AS pendingCount,
+            SUM(CASE WHEN o.ins_state IN (0,1,2,3) AND o.appointed &lt; NOW() THEN 1 ELSE 0 END) AS overdueCount
+        FROM (
+            SELECT 0 AS n UNION SELECT 1 UNION SELECT 2 UNION SELECT 3 UNION SELECT 4
+            UNION SELECT 5 UNION SELECT 6 UNION SELECT 7 UNION SELECT 8 UNION SELECT 9
+            UNION SELECT 10 UNION SELECT 11 UNION SELECT 12 UNION SELECT 13 UNION SELECT 14
+        ) days
+        LEFT JOIN ins_order o ON DATE(o.create_time) = DATE_SUB(CURDATE(), INTERVAL n DAY)
+        LEFT JOIN ins_sample s ON o.id = s.ins_order_id
+        GROUP BY date
+        ORDER BY date ASC
+    </select>
+
+    <!-- 鏈潵15澶╀换鍔� -->
+    <select id="getFutureDays" resultType="com.ruoyi.report.vo.TaskCalendarVo">
+        SELECT
+            DATE_FORMAT(DATE_ADD(CURDATE(), INTERVAL n DAY), '%Y-%m-%d') AS date,
+            COUNT(DISTINCT s.id) AS sampleCount,
+            0 AS finishedCount,
+            SUM(CASE WHEN o.ins_state IN (0,1,2,3) THEN 1 ELSE 0 END) AS pendingCount,
+            0 AS overdueCount
+        FROM (
+            SELECT 0 AS n UNION SELECT 1 UNION SELECT 2 UNION SELECT 3 UNION SELECT 4
+            UNION SELECT 5 UNION SELECT 6 UNION SELECT 7 UNION SELECT 8 UNION SELECT 9
+            UNION SELECT 10 UNION SELECT 11 UNION SELECT 12 UNION SELECT 13 UNION SELECT 14
+        ) days
+        LEFT JOIN ins_order o ON DATE(o.appointed) = DATE_ADD(CURDATE(), INTERVAL n DAY) AND o.ins_state IN (0,1,2,3)
+        LEFT JOIN ins_sample s ON o.id = s.ins_order_id
+        GROUP BY date
+        ORDER BY date ASC
+    </select>
+
+    <!-- 鎻愪氦鎺掕(鍘熷璁板綍) -->
+    <select id="getOriginalRecordRanking" resultType="com.ruoyi.report.vo.RankingVo">
+        SELECT
+            u.id AS userId,
+            u.name AS userName,
+            d.dept_name AS deptName,
+            COUNT(*) AS submitCount
+        FROM ins_product p
+        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
+        LEFT JOIN ins_sample s ON p.ins_sample_id = s.id
+        LEFT JOIN ins_order o ON s.ins_order_id = o.id
+        WHERE o.ins_time 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>
+        GROUP BY u.id, u.name, d.dept_name
+        ORDER BY submitCount DESC
+        LIMIT 10
+    </select>
+
+    <!-- 鎻愪氦鎺掕(鎶ュ憡) -->
+    <select id="getReportRanking" resultType="com.ruoyi.report.vo.RankingVo">
+        SELECT
+            u.id AS userId,
+            u.name AS userName,
+            d.dept_name AS deptName,
+            COUNT(*) AS submitCount
+        FROM ins_report r
+        LEFT JOIN user u ON r.write_user_id = u.id
+        LEFT JOIN sys_dept d ON u.dept_id = d.dept_id
+        WHERE r.state >= 1
+        <if test="dto.startTime != null and dto.startTime != ''">
+            AND r.create_time >= #{dto.startTime}
+        </if>
+        <if test="dto.endTime != null and dto.endTime != ''">
+            AND r.create_time &lt;= #{dto.endTime}
+        </if>
+        GROUP BY u.id, u.name, d.dept_name
+        ORDER BY submitCount DESC
+        LIMIT 10
+    </select>
+
+    <!-- 杩�30澶╂楠岀粨鏋� -->
+    <select id="getInsResultByDays" resultType="java.util.Map">
+        SELECT
+            DATE_FORMAT(DATE_SUB(CURDATE(), INTERVAL n DAY), '%Y-%m-%d') AS date,
+            SUM(CASE WHEN p.ins_result = 1 THEN 1 ELSE 0 END) AS qualified,
+            SUM(CASE WHEN p.ins_result = 0 THEN 1 ELSE 0 END) AS unqualified,
+            COUNT(*) AS total
+        FROM (
+            SELECT 0 AS n UNION SELECT 1 UNION SELECT 2 UNION SELECT 3 UNION SELECT 4
+            UNION SELECT 5 UNION SELECT 6 UNION SELECT 7 UNION SELECT 8 UNION SELECT 9
+            UNION SELECT 10 UNION SELECT 11 UNION SELECT 12 UNION SELECT 13 UNION SELECT 14
+            UNION SELECT 15 UNION SELECT 16 UNION SELECT 17 UNION SELECT 18 UNION SELECT 19
+            UNION SELECT 20 UNION SELECT 21 UNION SELECT 22 UNION SELECT 23 UNION SELECT 24
+            UNION SELECT 25 UNION SELECT 26 UNION SELECT 27 UNION SELECT 28 UNION SELECT 29
+        ) days
+        LEFT JOIN ins_product p ON DATE(p.create_time) = DATE_SUB(CURDATE(), INTERVAL n DAY)
+        LEFT JOIN ins_sample s ON p.ins_sample_id = s.id
+        LEFT JOIN ins_order o ON s.ins_order_id = o.id
+        WHERE p.ins_result IS NOT NULL
+        <if test="orderType != null and orderType != ''">
+            AND o.order_type = #{orderType}
+        </if>
+        GROUP BY date
+        ORDER BY date ASC
+    </select>
+
+    <!-- 鑾峰彇璇煶鎾姤闃熷垪 -->
+    <select id="getVoiceQueue" resultType="java.util.Map">
+        SELECT
+            id,
+            event_type AS eventType,
+            event_name AS eventName,
+            details,
+            voice_text AS voiceText,
+            priority,
+            create_time AS createTime
+        FROM voice_queue
+        WHERE status = 0
+        ORDER BY priority DESC, create_time ASC
+        LIMIT 10
+    </select>
+
+</mapper>
\ No newline at end of file

--
Gitblit v1.9.3