KKSU
2024-04-17 0d9efa874050e31617640f4938184c0695a1083d
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
<?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="cc.mrbird.febs.dapp.mapper.DappFundFlowDao">
 
    <select id="selectInPage" resultType="cc.mrbird.febs.dapp.entity.DappFundFlowEntity">
        select
        a.*,
               b.address address
        from dapp_fund_flow a
        left join dapp_member b on a.member_id = b.id
        <where>
            <if test="record.memberId != null">
                and a.member_id = #{record.memberId}
            </if>
            <if test="record.type != null">
                and a.type = #{record.type}
            </if>
            <if test="record.type != null">
                and a.type = #{record.type}
            </if>
            <if test="record.status != null">
                and a.status = #{record.status}
            </if>
            <if test="record.address != null and record.address != ''">
                and b.address = #{record.address}
            </if>
            <if test="record.fromHash != null and record.fromHash != ''">
                and a.from_hash = #{record.fromHash}
            </if>
            <if test="record.toHash != null and record.toHash != ''">
                and a.to_hash = #{record.toHash}
            </if>
        </where>
        order by a.create_time desc
    </select>
 
    <select id="selectZyInPage" resultType="cc.mrbird.febs.dapp.entity.DappAchieve">
        select
        a.*
        from dapp_achieve a
        <where>
            <if test="record.state != null">
                and a.state = #{record.state}
            </if>
            <if test="record.memberId != null">
                and a.member_id=#{record.memberId}
            </if>
        </where>
        order by a.create_time desc
    </select>
 
    <select id="selectListForMemberAndDay" resultType="cc.mrbird.febs.dapp.entity.DappFundFlowEntity">
        select * from dapp_fund_flow
        where member_id=#{memberId} and date_format(create_time, '%Y-%m-%d') = date_format(now(), '%Y-%m-%d')
        and type=#{type}
        <if test="type != 3">
            and status!=3
        </if>
    </select>
 
    <select id="selectByFromHash" resultType="cc.mrbird.febs.dapp.entity.DappFundFlowEntity">
        select * from dapp_fund_flow
        where from_hash=#{txHash}
        <if test="status != null">
            and status=#{status}
        </if>
    </select>
 
    <select id="selectFundFlowListByAddress" resultType="cc.mrbird.febs.dapp.entity.DappFundFlowEntity">
        select * from dapp_fund_flow a, dapp_member b
        where b.address=#{address}
        <if test="status != null">
            and a.status=#{status}
        </if>
    </select>
 
    <select id="selectAmountTotalByType" resultType="java.util.HashMap">
        select
            MAX(if(type = 1, a.amount, 0)) buy
             , MAX(if(type = 2, a.amount, 0)) sale
             , MAX(if(type = 3, a.amount, 0)) mine
             , MAX(if(type = 4, a.amount, 0)) teamReward
        from (select type, sum(amount) amount
              from dapp_fund_flow
              where member_id=#{memberId}
              group by type
             ) a
    </select>
 
    <select id="selectAmountTotalByTypeAndMemberIdAndDate" resultType="java.math.BigDecimal">
        select
        IFNULL(sum(amount), 0)
        from
        dapp_fund_flow
        where
        member_id = #{memberId}
        and type = #{type}
        <if test="date != null">
            and date_format(create_time, '%Y-%m-%d') = date_format(#{date}, '%Y-%m-%d');
        </if>
    </select>
 
 
 
    <select id="findMoneyFlowVos" resultType="cc.mrbird.febs.dapp.vo.MoneyFlowVo">
        select
        a.amount amount,
        a.type type,
        a.create_time createTime
        from dapp_fund_flow a
        where
            a.type in (2,3,5,6,9)
                and a.member_id=#{record.memberId}
        order by a.create_time desc
    </select>
 
 
 
    <select id="selectInPages" resultType="cc.mrbird.febs.dapp.entity.DappFundFlowEntity">
        select
        a.amount,
        a.type,
        a.status,
        b.address address
        from dapp_fund_flow a
        left join dapp_member b on a.member_id = b.id
        <where>
            <if test="record.memberId != null">
                and a.member_id = #{record.memberId}
            </if>
            <if test="record.type != null">
                and a.type = #{record.type}
            </if>
            <if test="record.type != null">
                and a.type = #{record.type}
            </if>
            <if test="record.status != null">
                and a.status = #{record.status}
            </if>
            <if test="record.address != null and record.address != ''">
                and b.address = #{record.address}
            </if>
            <if test="record.fromHash != null and record.fromHash != ''">
                and a.from_hash = #{record.fromHash}
            </if>
            <if test="record.toHash != null and record.toHash != ''">
                and a.to_hash = #{record.toHash}
            </if>
        </where>
        order by a.create_time desc
    </select>
</mapper>