yujian
2020-06-08 7912a94e5de72b628bde39b16e6c7b21172910eb
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
package com.yeshi.fanli.dao.mybatis.integral;
 
import java.math.BigDecimal;
import java.util.Date;
import java.util.List;
 
import org.apache.ibatis.annotations.Param;
 
import com.yeshi.fanli.dao.BaseMapper;
import com.yeshi.fanli.entity.integral.IntegralDetail;
import com.yeshi.fanli.vo.integral.IntegralMonthVO;
 
public interface IntegralDetailMapper extends BaseMapper<IntegralDetail> {
 
    /**
     * 根据唯一值查询明细
     * @param uniqueKey
     * @return
     */
    IntegralDetail getDetailByUniqueKey(@Param("uniqueKey")String uniqueKey);
    
    /**
     * 获取用户总共有多少记录数据
     * 
     * @param uid
     * @return
     */
    Long selectCountByUid(@Param("uid") Long uid, @Param("type")Integer type);
    
    /**
     * 按用户ID和最大时间检索月份的数量
     * 
     * @param uid
     * @param maxDate
     * @return
     */
    int selectMonthCountByUid(@Param("uid") Long uid, @Param("date") Date maxDate, @Param("type")Integer type);
    
    
    /**
     * 按最大的创建时间和用户ID检索数量
     * 
     * @param uid
     * @param date
     * @return
     */
    Long selectCountByUidAndMaxCreateTime(@Param("uid") Long uid, @Param("date") Date date, @Param("type")Integer type);
    
    
    /**
     * 按最大的创建时间和用户ID检索列表
     * 
     * @param uid
     * @param date
     * @return
     */
    List<IntegralDetail> selectByMaxCreateTime(@Param("uid") Long uid, @Param("date") Date date, @Param("count") int count, @Param("type")Integer type);
    
    
    /**
     * 通过用户ID和返回的最大时间的详情ID来获取下一页的数据
     * 
     * @param uid
     * @param id
     * @param count
     * @return
     */
    List<IntegralDetail> selectByUidWithIndexId(@Param("uid") Long uid, @Param("id") Long id, @Param("count") int count, @Param("type")Integer type);
    
    
    /**
     * 统计某个月份的收入与支出
     * 
     * @param uid
     * @param dateFormat
     * @return
     */
    List<IntegralMonthVO> selectMonthMoneyByUid(@Param("uid") Long uid, @Param("dateFormat") List<String> dateFormat);
    
    
    /**
     * 统计历史到账
     * @param uniqueKey
     * @return
     */
    BigDecimal getCumulativeMoney(@Param("uid") Long uid);
    
    
    /**
     *  统计当日新增金币
     * @param uniqueKey
     * @return
     */
    Long countNewAddByDate(@Param("preDay") String preDay);
    
    /**
     * 列表查询
     * @param start
     * @param count
     * @param key
     * @return
     */
    List<IntegralDetail> listQuery(@Param("start")long start, @Param("count")int count, @Param("key")String key);
    
    Long countQuery(@Param("key")String key);
    
    /**
     * 共计已消耗金币数
     * @param uid
     * @return
     */
    Long sumUseGoldCoin(@Param("uid")Long uid);
}