Project

General

Profile

Download (2.65 KB) Statistics
| Branch: | Revision:
1
/**
2
* Copyright (C) 2007 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

    
10
package eu.etaxonomy.cdm.io.algaterra.validation;
11

    
12
import java.sql.ResultSet;
13
import java.sql.SQLException;
14

    
15
import org.apache.log4j.Logger;
16

    
17
import eu.etaxonomy.cdm.io.algaterra.AlgaTerraImportConfigurator;
18
import eu.etaxonomy.cdm.io.berlinModel.in.BerlinModelImportConfigurator;
19
import eu.etaxonomy.cdm.io.berlinModel.in.BerlinModelImportState;
20
import eu.etaxonomy.cdm.io.common.IOValidator;
21
import eu.etaxonomy.cdm.io.common.Source;
22

    
23
/**
24
 * @author a.mueller
25
 * @since 17.02.2010
26
 * @version 1.0
27
 */
28
public class AlgaTerraMorphologyImportValidator implements IOValidator<BerlinModelImportState> {
29
	private static final Logger logger = Logger.getLogger(AlgaTerraMorphologyImportValidator.class);
30

    
31

    
32
	@Override
33
	public boolean validate(BerlinModelImportState state) {
34
		boolean result = true;
35
		AlgaTerraImportConfigurator config = (AlgaTerraImportConfigurator)state.getConfig();
36
		result &= checkMissingCultureStrains(config);
37
		//result &= checkPartOfJournal(bmiConfig);
38
		System.out.println("Checking for Morphology not yet implemented");
39
		return result;
40
	}
41
	
42
	
43
	//******************************** CHECK *************************************************
44
		
45
		private static boolean checkMissingCultureStrains(AlgaTerraImportConfigurator config){
46
			try {
47
				boolean result = true;
48
				Source source = config.getSource();
49
				String strQuery = "SELECT mf.morphoFactId, mf.CultureStrainNo, eco.ecoFactId " +
50
						" FROM MorphoFact mf LEFT JOIN EcoFact eco ON eco.CultureStrain  = mf.CultureStrainNo " +
51
						" WHERE CultureStrainNo IS NOT NULL AND ecoFactId IS NULL " +
52
						" ORDER BY MorphoFactId ";
53

    
54
				ResultSet resulSet = source.getResultSet(strQuery);
55
				boolean firstRow = true;
56
				while (resulSet.next()){
57
					if (firstRow){
58
						System.out.println("========================================================");
59
						System.out.println("There are MorphoFacts with no matching EcoFacts!");
60
						System.out.println("========================================================");
61
					}
62
					int morphoFactId = resulSet.getInt("morphoFactId");
63
					String cultureStrain = resulSet.getString("CultureStrainNo");
64
					
65
					System.out.println("MorphoFactId:" + morphoFactId + "\n  cultureStrainNo: " + cultureStrain);
66
					result = firstRow = false;
67
				}
68
				
69
				return result;
70
			} catch (SQLException e) {
71
				e.printStackTrace();
72
				return false;
73
			}
74
		}
75

    
76
}
(3-3/5)