智慧农业后台管理
guoshilong
2022-09-28 5f7f52e93266dc8795ad1543b333a64444c22727
src/main/java/org/springblade/modules/recovery/mapper/RecoveryMapper.xml
@@ -4,10 +4,11 @@
    <!--自定义查询采收记录分页数据-->
    <select id="selectRecoveryPage" resultType="org.springblade.modules.recovery.vo.RecoveryVO">
        select sr.*,sl.land_name landName,ss.strain_name strainName,user.real_name as realName from sys_recovery sr
        select sr.*,sl.land_name landName,ss.strain_name strainName,user.real_name as realName,GROUP_CONCAT(tr.id) AS trIds from sys_recovery sr
        left join sys_land sl on sl.id = sr.land_id
        left join sys_strain ss on ss.id = sr.strain_id
        left join blade_user user ON user.id = sr.operator
        LEFT JOIN sys_traceability tr ON tr.recovery_id = sr.id
        where 1=1
        <if test="recovery.strainName!=null and recovery.strainName!=''">
            and ss.strain_name like concat ('%',#{recovery.strainName},'%')
@@ -29,10 +30,18 @@
        </if>
        <if test="recovery.farmId != null and recovery.farmId != ''">
            and sl.farm_id = #{recovery.farmId}
            and sr.dept_id = #{recovery.farmId}
        </if>
        <if test="recovery.tenantId!=null and recovery.tenantId!=''">
            and sr.tenant_id = #{recovery.tenantId}
        </if>
        <if test="recovery.startTime != null and recovery.startTime !=''">
            AND DATE_FORMAT(sr.time,'%Y-%m-%d') &gt;= #{recovery.startTime}
        </if>
        <if test="recovery.endTime != null and recovery.endTime !=''">
            and DATE_FORMAT(sr.time,'%Y-%m-%d') &lt;= #{recovery.endTime}
        </if>
        GROUP BY sr.id
        ORDER BY sr.create_time DESC
    </select>
@@ -57,7 +66,11 @@
        where sr.id = #{recoveryId}
    </select>
    <select id="recoveryStatistics" resultType="org.springblade.modules.recovery.vo.RecoveryVO">
        SELECT sr.strain_id,SUM(sr.weight) AS weight,sr.dept_id,strain.strain_name,strain.url
        SELECT
            sr.strain_id,
            SUM(sr.weight) AS weight,
            strain.strain_name,
            strain.url
        FROM sys_recovery sr
        LEFT JOIN sys_strain strain ON sr.strain_id = strain.id
        WHERE 1=1
@@ -65,11 +78,81 @@
            AND sr.dept_id = #{recovery.deptId}
        </if>
        <if test="recovery.startTime != null and recovery.startTime !=''">
            AND DATE_FORMAT(sr.create_time,'%Y-%m-%d') &gt;= #{recovery.startTime}
            AND DATE_FORMAT(sr.time,'%Y-%m-%d') &gt;= #{recovery.startTime}
        </if>
        <if test="recovery.endTime != null and recovery.endTime !=''">
            and DATE_FORMAT(sr.create_time,'%Y-%m-%d') &lt;= #{recovery.endTime}
            and DATE_FORMAT(sr.time,'%Y-%m-%d') &lt;= #{recovery.endTime}
        </if>
        GROUP BY strain_id
        GROUP BY sr.strain_id
        UNION
        SELECT a.process_id,SUM(a.process_num),a.machining_type,a.machining_tp FROM
        (
            SELECT DISTINCT
            p.process_id,
            p.process_num,
            m.machining_type,
            m.machining_tp
            FROM sys_process p
            LEFT JOIN sys_machining m ON p.process_id = m.id
            LEFT JOIN sys_land sl ON sl.id = p.land_id
            LEFT JOIN sys_process_inv inv ON inv.product_id = p.process_id
            WHERE 1=1 AND p.is_deleted = 0
            <if test="recovery.deptId !=null and recovery.deptId !=''">
                AND( sl.farm_id = #{recovery.deptId} OR (inv.fps_id = #{recovery.deptId} AND p.land_id IS NULL))
            </if>
            <if test="recovery.startTime != null and recovery.startTime !=''">
                AND DATE_FORMAT(p.sale_time,'%Y-%m-%d') &gt;= #{recovery.startTime}
            </if>
            <if test="recovery.endTime != null and recovery.endTime !=''">
                and DATE_FORMAT(p.sale_time,'%Y-%m-%d') &lt;= #{recovery.endTime}
            </if>
        ) a GROUP BY a.process_id
    </select>
    <select id="recoveryStatisticsx" resultType="org.springblade.modules.recovery.vo.RecoveryVO">
        SELECT
        sr.strain_id,
        SUM(sr.weight) AS weight,
        strain.strain_name,
        strain.url
        FROM sys_recovery sr
        LEFT JOIN sys_strain strain ON sr.strain_id = strain.id
        WHERE 1=1
        <if test="recovery.deptId !=null and recovery.deptId !=''">
            AND sr.dept_id = #{recovery.deptId}
        </if>
        <if test="recovery.startTime != null and recovery.startTime !=''">
            AND DATE_FORMAT(sr.time,'%Y-%m-%d') &gt;= #{recovery.startTime}
        </if>
        <if test="recovery.endTime != null and recovery.endTime !=''">
            and DATE_FORMAT(sr.time,'%Y-%m-%d') &lt;= #{recovery.endTime}
        </if>
        GROUP BY sr.strain_id
        UNION
        SELECT a.process_id,SUM(a.process_num),a.machining_type,a.machining_tp FROM
        (
        SELECT DISTINCT
        p.process_id,
        p.process_num,
        m.machining_type,
        m.machining_tp
        FROM sys_process p
        LEFT JOIN sys_machining m ON p.process_id = m.id
        LEFT JOIN sys_land sl ON sl.id = p.land_id
        LEFT JOIN sys_process_inv inv ON inv.product_id = p.process_id
        WHERE 1=1 AND p.is_deleted = 0
        <if test="recovery.deptId !=null and recovery.deptId !=''">
            AND( sl.farm_id = #{recovery.deptId} OR (inv.fps_id = #{recovery.deptId} AND p.land_id IS NULL))
        </if>
        <if test="recovery.startTime != null and recovery.startTime !=''">
            AND DATE_FORMAT(p.sale_time,'%Y-%m-%d') &gt;= #{recovery.startTime}
        </if>
        <if test="recovery.endTime != null and recovery.endTime !=''">
            and DATE_FORMAT(p.sale_time,'%Y-%m-%d') &lt;= #{recovery.endTime}
        </if>
        ) a GROUP BY a.process_id
    </select>
</mapper>