1
zj
2025-06-25 a0361e762fc672d844ef15e18db5971893cce2bf
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
package project.log.internal;
 
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
import org.apache.commons.lang3.StringUtils;
 
import kernel.web.ApplicationUtil;
import kernel.web.Page;
import project.log.MoneyLog;
import project.log.MoneyLogService;
 
public class MoneyLogServiceImpl implements MoneyLogService {
    
    public void save(MoneyLog moneyLog) {
        if(null==moneyLog) return;
        moneyLog.setCreateTime(new Date());
        if(null==moneyLog.getId()) moneyLog.setId(ApplicationUtil.getCurrentTimeUUID());
        
        ApplicationUtil.executeInsert(moneyLog);
    }
 
    public Page pagedQuery(int pageNo, int pageSize, String category, String contentType, String partyId) {
        if (pageNo <= 0) pageNo = 1;
        
        StringBuilder sqlBuilder=new StringBuilder("WHERE 1=1 ");
        ArrayList<Object> params=new ArrayList<Object>();
        if (StringUtils.isNotEmpty(category)) {
            sqlBuilder.append("AND CATEGORY=? ");
            params.add(category);
        }
        
        if (StringUtils.isNotEmpty(contentType)) {
            sqlBuilder.append("AND CONTENT_TYPE=? ");
            params.add(contentType);
        }
        
        if (StringUtils.isNotEmpty(partyId)) {
            sqlBuilder.append("AND PARTY_ID=? ");
            params.add(partyId);
        }
        
        Page page = new Page(pageNo, pageSize, Integer.MAX_VALUE);
        sqlBuilder.append("ORDER BY CREATE_TIME DESC LIMIT ?,?");
        params.add(page.getFirstElementNumber());
        params.add(pageSize);
        
        List<MoneyLog> list=ApplicationUtil.executeSelect(MoneyLog.class, sqlBuilder.toString(), params.toArray(new Object[params.size()]));
        page.setElements(list);
        return page;
    }
    
    public Map<String,Object> sumBSalance(String category, String contentType, String partyId) {
        String sql = "SELECT ROUND(sum(IF(CREATE_TIME>=date(now()), amount, 0)),2) as dateAmount,ROUND(IFNULL(SUM(amount),0),2) as sumAmount FROM T_MONEY_LOG where category=? and content_type=? and party_id=?";
        List<HashMap> queryForList=ApplicationUtil.executeDQL(sql,new Object[] {category,contentType,partyId},HashMap.class);
        return (null==queryForList || queryForList.isEmpty())?null:queryForList.get(0);
    }
 
    public List<MoneyLog> findLogsByConentTypeAndDate(String type, String date) {
        return ApplicationUtil.executeDQL("SELECT * FROM T_MONEY_LOG WHERE CONTENT_TYPE =? AND DATE(CREATE_TIME) =DATE(?)",new Object[] {type,date},MoneyLog.class);
    }
}