Project

General

Profile

Download (3.89 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.test_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 doTaxa = false;
45
    static final boolean doDescriptions = true;
46

    
47
    static final boolean doConcurrent = false;
48
    //auditing
49
    static final boolean registerAuditing = false;
50

    
51
// ***************** ALL ************************************************//
52

    
53
//    >50 records
54
//    UUID uuidTaxonNodeFilter = UUID.fromString("0e8bc793-f434-47c4-ba82-650c3bbd83bf");
55
    //>17000 records
56
//    UUID uuidTaxonNodeFilter = UUID.fromString("7ee4983b-78a3-44c5-9af2-beb0494b5fc8");
57
    //complete
58
    UUID uuidTaxonNodeFilter = UUID.fromString("feaa3025-a4a9-499a-b62f-15b3b96e5c55");
59

    
60

    
61
    private void doImport(ICdmDataSource source, ICdmDataSource destination, DbSchemaValidation hbm2dll){
62

    
63
        String importFrom = " import from "+ source.getDatabase() + " to "+ destination.getDatabase() + " ...";
64
        System.out.println("Start"+importFrom);
65

    
66
        FauEu2CdmImportConfigurator config = FauEu2CdmImportConfigurator.NewInstance(source,  destination);
67
        config.setConcurrent(doConcurrent);
68
        config.setDoTaxa(doTaxa);
69
        config.setDoDescriptions(doDescriptions);
70

    
71
        IProgressMonitor monitor = config.getProgressMonitor();
72

    
73
//        config.setDoTaxa(doTaxa);
74
        config.setDbSchemaValidation(hbm2dll);
75
        config.getTaxonNodeFilter().orSubtree(uuidTaxonNodeFilter);
76
        config.getTaxonNodeFilter().setOrder(ORDER.TREEINDEX);
77
        if (doConcurrent){
78
            ITaxonNodeOutStreamPartitioner partitioner = TaxonNodeOutStreamPartitionerConcurrent
79
                    .NewInstance(config.getSource(), config.getTaxonNodeFilter(),
80
                            8, monitor, 1, TaxonNodeOutStreamPartitioner.fullPropertyPaths);
81
            config.setPartitioner(partitioner);
82
        }
83

    
84
        config.setCheck(check);
85
//        config.setRecordsPerTransaction(partitionSize);
86

    
87
        config.setRegisterAuditing(registerAuditing);
88

    
89
        // invoke import
90
        CdmDefaultImport<FauEu2CdmImportConfigurator> myImport = new CdmDefaultImport<>();
91
        myImport.invoke(config);
92

    
93
        System.out.println("End" + importFrom);
94
    }
95

    
96
    public static void main(String[] args) {
97
        ICdmDataSource cdmDB = CdmDestinations.chooseDestination(args) != null ? CdmDestinations.chooseDestination(args) : cdmDestination;
98
        FauEu2CdmActivator myImport = new FauEu2CdmActivator();
99
        myImport.doImport(fauEuSource, cdmDB, DbSchemaValidation.VALIDATE);
100
        System.exit(0);
101
    }
102
}
(3-3/12)