Project

General

Profile

Download (2.79 KB) Statistics
| Branch: | Tag: | Revision:
1
/**
2
* Copyright (C) 2009 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.database.update.v40_41;
10

    
11
import java.sql.ResultSet;
12
import java.sql.SQLException;
13
import java.util.List;
14

    
15
import org.apache.log4j.Logger;
16

    
17
import eu.etaxonomy.cdm.common.monitor.IProgressMonitor;
18
import eu.etaxonomy.cdm.database.ICdmDataSource;
19
import eu.etaxonomy.cdm.database.update.CaseType;
20
import eu.etaxonomy.cdm.database.update.ISchemaUpdaterStep;
21
import eu.etaxonomy.cdm.database.update.SchemaUpdateResult;
22
import eu.etaxonomy.cdm.database.update.SchemaUpdaterStepBase;
23
import eu.etaxonomy.cdm.model.name.NomenclaturalCode;
24

    
25

    
26
/**
27
 * Updates the CdmPreference NomenclaturalCode  #3658
28
 *
29
 * @author a.mueller
30
 * @since 13.10.2016
31
 */
32
public class NomenclaturalCodeUpdater extends SchemaUpdaterStepBase {
33
    private static final Logger logger = Logger.getLogger(NomenclaturalCodeUpdater.class);
34

    
35
	private static final String stepName = "Update nomenclatural code";
36

    
37
// **************************** STATIC METHODS ********************************/
38

    
39
	public static final NomenclaturalCodeUpdater NewInstance(List<ISchemaUpdaterStep> stepList){
40
		NomenclaturalCodeUpdater result = new NomenclaturalCodeUpdater();
41
		stepList.add(result);
42
		return result;
43
	}
44

    
45
	private NomenclaturalCodeUpdater() {
46
		super(stepName);
47
	}
48

    
49
    @Override
50
    public void invoke(ICdmDataSource datasource, IProgressMonitor monitor,
51
            CaseType caseType, SchemaUpdateResult result) throws SQLException {
52

    
53
	    String existsSql = " SELECT count(*) FROM @@CdmPreference@@ "
54
	            + " WHERE key_predicate = 'model.name.NC' AND key_subject = '/'";
55
	    existsSql = caseType.replaceTableNames(existsSql);
56
	    if (((Number)datasource.getSingleValue(existsSql)).intValue() > 0 ){
57
	        return;
58
	    }
59

    
60
	    String sql = "SELECT count(DTYPE) as n, DTYPE FROM @@TaxonNameBase@@ "
61
	            + " GROUP BY DTYPE ORDER BY count(DTYPE) DESC ";
62
	    sql = caseType.replaceTableNames(sql);
63
	    ResultSet rs = datasource.executeQuery(sql);
64
	    if (rs.next()){
65
	        String dtype = rs.getString(2);
66
	        NomenclaturalCode code = NomenclaturalCode.fromDtype(dtype);
67

    
68
	        if (code != null){
69
	            String insertSql = " INSERT INTO @@CdmPreference@@ (key_predicate, key_subject, value)"
70
	                    + " VALUES ('model.name.NC','/','eu.etaxonomy.cdm.model.name.NomenclaturalCode.%s')";
71

    
72
	            insertSql = String.format(insertSql, code.getUuid());
73
	            insertSql = caseType.replaceTableNames(insertSql);
74
	            datasource.executeUpdate(insertSql);
75
	            logger.warn("Nomenclatural code updated");
76
	        }
77
	    }
78
	    return;
79
	}
80

    
81
}
(1-1/3)