Project

General

Profile

Download (3.48 KB) Statistics
| Branch: | Revision:
1
/**
2
* Copyright (C) 2019 EDIT
3
* European Distributed Institute of Taxonomy
4
* http://www.e-taxonomy.eu
5
*
6
* The contents of this file are subject to the Mozilla Public License Version 1.1
7
* See LICENSE.TXT at the top of this package for the full license terms.
8
*/
9
package eu.etaxonomy.cdm.app.pesi;
10

    
11
import java.util.UUID;
12

    
13
import org.apache.log4j.Logger;
14

    
15
import eu.etaxonomy.cdm.app.common.CdmDestinations;
16
import eu.etaxonomy.cdm.common.monitor.IProgressMonitor;
17
import eu.etaxonomy.cdm.database.DbSchemaValidation;
18
import eu.etaxonomy.cdm.database.ICdmDataSource;
19
import eu.etaxonomy.cdm.filter.TaxonNodeFilter.ORDER;
20
import eu.etaxonomy.cdm.io.common.CdmDefaultImport;
21
import eu.etaxonomy.cdm.io.common.IImportConfigurator.CHECK;
22
import eu.etaxonomy.cdm.io.common.ITaxonNodeOutStreamPartitioner;
23
import eu.etaxonomy.cdm.io.common.TaxonNodeOutStreamPartitioner;
24
import eu.etaxonomy.cdm.io.common.TaxonNodeOutStreamPartitionerConcurrent;
25
import eu.etaxonomy.cdm.io.pesi.fauEu2Cdm.FauEu2CdmImportConfigurator;
26

    
27
/**
28
 * @author a.mueller
29
 * @since 17.08.2019
30
 */
31
public class FauEu2CdmActivator {
32

    
33
    @SuppressWarnings("unused")
34
    private static final Logger logger = Logger.getLogger(FauEu2CdmActivator.class);
35

    
36
    static final ICdmDataSource fauEuSource = CdmDestinations.cdm_pesi_fauna_europaea();
37
    static final ICdmDataSource cdmDestination = CdmDestinations.cdm_test_local_pesi_leer2();
38

    
39
    //check - import
40
    static final CHECK check = CHECK.IMPORT_WITHOUT_CHECK;
41

    
42
    static final int partitionSize = 5000;
43

    
44
    static final boolean doConcurrent = false;
45

    
46
// ***************** ALL ************************************************//
47

    
48
//    >50 records
49
    UUID uuidTaxonNodeFilter = UUID.fromString("0e8bc793-f434-47c4-ba82-650c3bbd83bf");
50
    //>17000 records
51
//    UUID uuidTaxonNodeFilter = UUID.fromString("7ee4983b-78a3-44c5-9af2-beb0494b5fc8");
52

    
53

    
54
    private void doImport(ICdmDataSource source, ICdmDataSource destination, DbSchemaValidation hbm2dll){
55

    
56
        String importFrom = " import from "+ source.getDatabase() + " to "+ destination.getDatabase() + " ...";
57
        System.out.println("Start"+importFrom);
58

    
59
        FauEu2CdmImportConfigurator config = FauEu2CdmImportConfigurator.NewInstance(source,  destination);
60

    
61
        IProgressMonitor monitor = config.getProgressMonitor();
62

    
63
//        config.setDoTaxa(doTaxa);
64
        config.setDbSchemaValidation(hbm2dll);
65
        config.getTaxonNodeFilter().orSubtree(uuidTaxonNodeFilter);
66
        config.getTaxonNodeFilter().setOrder(ORDER.TREEINDEX);
67
        if (doConcurrent){
68
            ITaxonNodeOutStreamPartitioner partitioner = TaxonNodeOutStreamPartitionerConcurrent
69
                    .NewInstance(config.getSource(), config.getTaxonNodeFilter(),
70
                            8, monitor, 1, TaxonNodeOutStreamPartitioner.fullPropertyPaths);
71
            config.setPartitioner(partitioner);
72
        }
73

    
74
        config.setCheck(check);
75
//        config.setRecordsPerTransaction(partitionSize);
76

    
77
        // invoke import
78
        CdmDefaultImport<FauEu2CdmImportConfigurator> myImport = new CdmDefaultImport<>();
79
        myImport.invoke(config);
80

    
81
        System.out.println("End" + importFrom);
82
    }
83

    
84
    /**
85
     * @param args
86
     */
87
    public static void main(String[] args) {
88
        ICdmDataSource cdmDB = CdmDestinations.chooseDestination(args) != null ? CdmDestinations.chooseDestination(args) : cdmDestination;
89
        FauEu2CdmActivator myImport = new FauEu2CdmActivator();
90
        myImport.doImport(fauEuSource, cdmDB, DbSchemaValidation.VALIDATE);
91
        System.exit(0);
92
    }
93
}
(2-2/11)