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
|
}
|