P15GEN2\59518
2024-05-29 d4210c7c4b04abde20037ea8aa0f54ef8a2649aa
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
package foundation.data.object;
 
import java.util.Date;
import java.util.Iterator;
 
import foundation.data.meta.field.FieldsRuntime;
import foundation.util.ContentBuilder;
import foundation.util.MapList;
import foundation.util.Util;
 
public class DataJoins implements Iterable<DataJoin> {
 
    private MapList<String, DataJoin> items;
    private String commaSeparator;
    private String joinSelectFields;
    private String joinSQL;
    private String[] joinTables;
    private boolean builded;
    private Date lastUpdateTime;
 
    
    public DataJoins() {
        items = new MapList<String, DataJoin>();
        builded = false;
        lastUpdateTime = new Date(0);
        joinTables = null;
    }
 
    public void loadOne(DataJoin dataJoin) {
        //1.
        items.add(dataJoin.getJoinDataName(), dataJoin);
        
        //2. 
        Date time = dataJoin.getUpdateTime();
        lastUpdateTime = lastUpdateTime.after(time) ? lastUpdateTime : time;
    }
 
    public void build() throws Exception {
        if (builded) {
            return;
        }
        
        //1. 
        for (DataJoin dataJoin: items) {
            dataJoin.build();
        }
        
        //2. build join select fields
        ContentBuilder joinFieldsBuilder = new ContentBuilder(", ");
        
        for (DataJoin dataJoin: items) {
            dataJoin.getJoinFields(joinFieldsBuilder);
        }
        
        joinSelectFields = joinFieldsBuilder.toString();
        
        //3. build join SQL
        ContentBuilder joinSQLBuilder = new ContentBuilder(Util.String_Return);
        
        for (DataJoin dataJoin: items) {
            joinSQLBuilder.append(dataJoin.getJoinSQL());
        }
        
        joinSQL = joinSQLBuilder.toString();
        
        //4. build commaSeparator
        commaSeparator = !Util.isEmpty(joinSelectFields) ? ", " : "";
        
        //5.
        int max = items.size();
        joinTables = new String[max];
        
        for (int i = 0; i < max; i++) {
            DataJoin dataJoin = items.get(i);
            joinTables[i] = dataJoin.getJoinDataName();
        }
        
        //6.
        builded = true;
    }
 
    public FieldsRuntime getJoinFieldsMeta(String tableName) {
        DataJoin dataJoin = items.get(tableName);
        
        if (dataJoin == null) {
            return null;
        }
        
        return dataJoin.getJoinFieldsMeta();
    }
    
    @Override
    public Iterator<DataJoin> iterator() {
        return items.iterator();
    }
 
    public String getCommaSeparator() {
        return commaSeparator;
    }
 
    public String getJoinSelectFields() {
        return joinSelectFields;
    }
 
    public String getJoinSQL() {
        return joinSQL;
    }
 
    public boolean isEmpty() {
        return items.isEmpty();
    }
    
    public String[] getJoinTables() {
        return joinTables;
    }
 
    public Date getLastUpdateTime() {
        return lastUpdateTime;
    }
 
    public int size() {
        return items.size();
    }
 
    
}