Statistics
| Revision:

svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.compat.cdc / org.gvsig.fmap.dal / org.gvsig.fmap.dal.swing / org.gvsig.fmap.dal.swing.impl / src / main / java / org / gvsig / fmap / dal / swing / impl / searchPostProcess / distinctOn / DistinctOn.java @ 45753

History | View | Annotate | Download (9.29 KB)

1
/*
2
 * To change this license header, choose License Headers in Project Properties.
3
 * To change this template file, choose Tools | Templates
4
 * and open the template in the editor.
5
 */
6
package org.gvsig.fmap.dal.swing.impl.searchPostProcess.distinctOn;
7

    
8

    
9
import java.io.File;
10
import java.util.Collection;
11
import java.util.HashMap;
12
import java.util.Map;
13
import java.util.Objects;
14
import java.util.UUID;
15

    
16
import org.gvsig.fmap.dal.DALLocator;
17
import org.gvsig.fmap.dal.DataManager;
18
import org.gvsig.fmap.dal.DataStoreParameters;
19
import org.gvsig.fmap.dal.exception.DataException;
20
import org.gvsig.fmap.dal.exception.ValidateDataParametersException;
21
import org.gvsig.fmap.dal.feature.EditableFeature;
22
import org.gvsig.fmap.dal.feature.EditableFeatureAttributeDescriptor;
23
import org.gvsig.fmap.dal.feature.EditableFeatureType;
24
import org.gvsig.fmap.dal.feature.Feature;
25
import org.gvsig.fmap.dal.feature.FeatureAttributeDescriptor;
26
import org.gvsig.fmap.dal.feature.FeatureAttributeEmulator;
27
import org.gvsig.fmap.dal.feature.FeatureQuery;
28
import org.gvsig.fmap.dal.feature.FeatureSet;
29
import org.gvsig.fmap.dal.feature.FeatureStore;
30
import org.gvsig.fmap.dal.feature.FeatureType;
31
import org.gvsig.fmap.dal.store.jdbc.JDBCNewStoreParameters;
32
import org.gvsig.fmap.dal.store.jdbc.JDBCServerExplorer;
33
import org.gvsig.fmap.dal.store.jdbc.JDBCServerExplorerParameters;
34
import org.gvsig.fmap.dal.swing.impl.searchPostProcess.distinctOn.AggregateOperation.AggregateOperationFactory;
35
import org.gvsig.fmap.dal.swing.searchPostProcess.AbstractSearchPostProcess;
36
import org.gvsig.fmap.dal.swing.searchPostProcess.SearchPostProcessFactory;
37
import org.gvsig.tools.ToolsLocator;
38
import org.gvsig.tools.dataTypes.DataType;
39
import org.gvsig.tools.dynobject.DynObject;
40
import org.gvsig.tools.folders.FoldersManager;
41
import org.gvsig.tools.util.HasAFile;
42
import org.slf4j.LoggerFactory;
43

    
44

    
45
/**
46
 *
47
 * @author jovivas
48
 */
49
public class DistinctOn extends AbstractSearchPostProcess{
50
    
51
    private static final org.slf4j.Logger LOGGER = LoggerFactory.getLogger(DistinctOnFactory.class);
52
    
53
    public DistinctOn (
54
        SearchPostProcessFactory factory,
55
        FeatureStore input,
56
        FeatureQuery query,
57
        DynObject parameters
58
        
59
    ){
60
        super( factory, input, query, parameters);
61

    
62
    }
63

    
64
    
65
    @Override
66
    public  SearchPostProcessResult execute (FeatureStore inputStore, FeatureQuery query, DynObject parameters){  
67
        String uniqueFieldName;
68
        
69
        uniqueFieldName = (String) parameters.getDynValue("field");
70
        
71
        try {
72
            // crear ruta de archivo temporal
73
            FoldersManager foldersManager = ToolsLocator.getFoldersManager();
74
            File tempFile = foldersManager.getUniqueTemporaryFile("distinctOn_process_"+ UUID.randomUUID().toString());
75
            
76
            // crear SERVER STORE
77
            DataManager dataManager = DALLocator.getDataManager();
78
            JDBCServerExplorerParameters serverParameters = (JDBCServerExplorerParameters) dataManager.createServerExplorerParameters("H2Spatial");
79
            ((HasAFile) serverParameters).setFile(tempFile);
80
            JDBCServerExplorer serverExplorer = (JDBCServerExplorer) dataManager.openServerExplorer("H2Spatial",serverParameters);
81

    
82
            
83
            //Crear tablas en server store
84
            JDBCNewStoreParameters parametersResults = serverExplorer.getAddParameters();
85
            parametersResults.setDynValue("Table", "results");
86
            FeatureType ft_inputStore = inputStore.getDefaultFeatureType();
87
            EditableFeatureType ft_inputStoreNoContainer = dataManager.createFeatureType();
88
            ft_inputStoreNoContainer.addAll(ft_inputStore);
89
            for (FeatureAttributeDescriptor attr : ft_inputStore) {
90
                DataType dataType = attr.getDataType();
91
                EditableFeatureAttributeDescriptor eattr = ft_inputStoreNoContainer.getEditableAttributeDescriptor(attr.getName());
92
                if (dataType.isContainer()){
93
                    ft_inputStoreNoContainer.remove(attr.getName());
94
                } 
95
                if (eattr.isComputed()){
96
                    eattr.setFeatureAttributeEmulator((FeatureAttributeEmulator) null);  
97
                }    
98
                if (eattr.isPrimaryKey()){
99
                    eattr.setIsPrimaryKey(false); 
100
                }
101
                if (eattr.allowIndexDuplicateds()){
102
                    eattr.setAllowIndexDuplicateds(true);
103
                }                  
104
            }
105
            Map<String, EditableFeatureAttributeDescriptor> allExtraColumns = new HashMap<>();
106
            for (EditableFeatureAttributeDescriptor column : ft_inputStore.getExtraColumns().getColumns()) {
107
                allExtraColumns.put(column.getName(), column);
108
            }
109
            for (EditableFeatureAttributeDescriptor column : query.getExtraColumn().getColumns()) {
110
                allExtraColumns.put(column.getName(), column);
111
            }
112
            if (allExtraColumns.size()>0) {
113
                for (EditableFeatureAttributeDescriptor column : allExtraColumns.values()) {
114
                    DataType dataType = column.getDataType();
115
                    if (!dataType.isContainer()){
116
                        ft_inputStoreNoContainer.add(column.getName(), column.getType(), column.getSize());
117
                    } 
118
                }
119
            }
120

    
121
            parametersResults.setDefaultFeatureType(ft_inputStoreNoContainer);     
122

    
123
            serverExplorer.add("H2Spatial", parametersResults, true);
124

    
125
            
126
            DataStoreParameters storeParametersResults = dataManager.createStoreParameters("H2Spatial");
127
            storeParametersResults.setDynValue("database_file",tempFile);
128
            storeParametersResults.setDynValue("Table","results");
129
            
130
            //Creaci?n del store con los resultados
131
            FeatureStore storeResults = (FeatureStore) dataManager.openStore("H2Spatial",storeParametersResults);
132

    
133
            // Creaci?n del Map con las funciones de agragado
134
            Map <String, AggregateOperation> aggregates = new HashMap <>();
135
            for (FeatureAttributeDescriptor attr : ft_inputStoreNoContainer) {
136
                if (parameters.hasDynValue(attr.getName())){
137
                    String operation = (String) parameters.getDynValue(attr.getName());
138
                    aggregates.put(
139
                            attr.getName(),
140
                            (AggregateOperation) aggregatesOperationFactories.get(operation).create()
141
                    );
142
                }                 
143
            }
144
            
145
            // distictOn
146
            
147
            storeResults.edit(FeatureStore.MODE_APPEND);
148

    
149
            FeatureSet features;
150
            if (query != null){
151
                features = inputStore.getFeatureSet(query);
152
            }else{
153
                features = inputStore.getFeatureSet();
154
            }
155
            EditableFeature lastFeature = null; 
156
            for (Feature feature : features) {
157
                if (lastFeature == null){
158
                    lastFeature=storeResults.createNewFeature(feature);
159
                    for (Map.Entry<String, AggregateOperation> entry : aggregates.entrySet()) {
160
                        String name = entry.getKey();
161
                        AggregateOperation operation = entry.getValue();
162
                        operation.reset();
163
                        Object value = feature.get(name);
164
                        if (operation.isApplicable(value)){
165
                            operation.perform(value);
166
                        }
167
                        lastFeature.set(name, operation.getValue()); 
168
                    }
169
                }
170
                if ( Objects.equals(feature.get(uniqueFieldName), lastFeature.get(uniqueFieldName))){
171
                    for (Map.Entry<String, AggregateOperation> entry : aggregates.entrySet()) {
172
                        String name = entry.getKey();
173
                        AggregateOperation operation = entry.getValue();
174
                        Object value = feature.get(name);
175
                        if (operation.isApplicable(value)){
176
                            operation.perform(value);
177
                        }
178
                        lastFeature.set(name, operation.getValue()); 
179
                    }
180
                }else{
181
                    storeResults.insert(lastFeature);
182
                    lastFeature = null; 
183
                }
184
            }
185

    
186
            storeResults.insert(lastFeature);
187
            
188
            storeResults.finishEditing();
189
//            storeUValues.finishEditing();
190
            
191
            SearchPostProcessResult searchPostProcessResult = new DefaultSearchPostProcessResult(storeResults,null);
192
            return searchPostProcessResult;
193
               
194
        } catch (DataException | ValidateDataParametersException ex) {
195
            LOGGER.warn("Can't execute distinct on search post process.", ex);
196
        }
197
                   
198
        return null;
199
    }
200
    
201
    private static Map<String, AggregateOperationFactory> aggregatesOperationFactories = new HashMap<>();
202
    public static void registerAggregateOperation(AggregateOperationFactory aggregateOperationFactory){
203
        aggregatesOperationFactories.put(aggregateOperationFactory.getName(), aggregateOperationFactory);
204
    }
205
    
206
    public static Collection<AggregateOperationFactory> getAggregatesOperationFactories(){
207
        return aggregatesOperationFactories.values();
208
    }
209
    
210
    
211
    
212
}
213