liyong
2 天以前 4635770544e2d57416ad88a8983ee293919f5fec
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
<?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.account.mapper.purchase.AccountPaymentApplicationMapper">
 
    <!-- 通用查询映射结果 -->
    <resultMap id="BaseResultMap" type="com.ruoyi.account.pojo.purchase.AccountPaymentApplication">
        <id column="id" property="id" />
        <result column="create_user" property="createUser" />
        <result column="create_time" property="createTime" />
        <result column="update_user" property="updateUser" />
        <result column="update_time" property="updateTime" />
        <result column="dept_id" property="deptId" />
        <result column="supplier_id" property="supplierId" />
        <result column="stock_in_record_ids" property="stockInRecordIds" />
        <result column="invoice_application_no" property="invoiceApplicationNo" />
        <result column="payment_method" property="paymentMethod" />
        <result column="payment_content" property="paymentContent" />
        <result column="apply_date" property="applyDate" />
        <result column="remark" property="remark" />
        <result column="status" property="status" />
        <result column="payment_amount" property="paymentAmount" />
    </resultMap>
     <select
         id="listPageAccountPaymentApplication"
         resultType="com.ruoyi.account.bean.vo.purchase.AccountPaymentApplicationVo">
        select * from (select apa.*,
               sm.supplier_name,
               GROUP_CONCAT(sir.inbound_batches SEPARATOR ',') AS inboundBatches
        from account_payment_application apa
        left join supplier_manage sm on apa.supplier_id = sm.id
        left join stock_in_record sir on FIND_IN_SET(sir.id, apa.stock_in_record_ids) > 0
        GROUP BY apa.id)A
        <where>
            <if test="req.supplierId != null">
                 AND A.supplier_id = #{req.supplierId}
            </if>
            <if test="req.invoiceApplicationNo != null and req.invoiceApplicationNo != ''">
                AND A.invoice_application_no LIKE CONCAT('%',#{req.invoiceApplicationNo},'%')
            </if>
             <if test="req.status != null">
                 AND A.status = #{req.status}
            </if>
            <if test="req.startDate != null and req.endDate != null">
                AND A.apply_date BETWEEN #{req.startDate} AND #{req.endDate}
            </if>
        </where>
    </select>
 
    <select id="getInboundBatchesBySupplier"
            resultType="com.ruoyi.account.bean.vo.purchase.PurchaseInboundVo">
        SELECT
            sir.id,
            sir.inbound_batches,
            pl.supplier_name,
            DATE(sir.create_time) AS inboundDate,
            p.product_name,
            pm.model as specification_model,
            sir.stock_in_num * slp.tax_inclusive_unit_price AS InboundAmount,
            pl.purchase_contract_number
            FROM stock_in_record sir
            -- 10 类型才关联质检表
            LEFT JOIN quality_inspect qi ON sir.record_type = 10 AND sir.record_id = qi.id
            -- 动态关联采购(自动适配 7 和 10)
            LEFT JOIN purchase_ledger pl
            ON pl.id = IF(sir.record_type = 7, sir.record_id, qi.purchase_ledger_id)
            -- 产品关联不动
            LEFT JOIN sales_ledger_product slp ON pl.id = slp.sales_ledger_id
            LEFT JOIN product_model pm ON sir.product_model_id = pm.id
            LEFT JOIN product p ON pm.product_id = p.id
            -- 条件
        WHERE sir.approval_status = 1 AND slp.type = 2
        AND sir.record_type IN ('7','10')
        and pl.supplier_id=#{supplierId}
 
        and sir.id NOT IN (
        SELECT DISTINCT SUBSTRING_INDEX(SUBSTRING_INDEX(a.stock_in_record_ids, ',', n.n), ',', -1)
        FROM account_payment_application a
        CROSS JOIN (
            SELECT 1 n UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL
            SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6
        ) n
        WHERE n.n &lt;= CHAR_LENGTH(a.stock_in_record_ids) - CHAR_LENGTH(REPLACE(a.stock_in_record_ids, ',', '')) + 1
        and a.status!=2
        )
 
        order by sir.id DESC
    </select>
 
    <select id="existsByStockInRecordId" resultType="java.lang.Boolean">
         SELECT COUNT(*) > 0
        FROM account_payment_application
        WHERE  status != 2
        <foreach collection="stockInRecordIds" item="id" open="(" separator=" OR " close=")">
            FIND_IN_SET(#{id}, stock_in_record_ids)
        </foreach>
    </select>
 
</mapper>