How to use Comparator in Java to sort

后端 未结 14 1818
时光取名叫无心
时光取名叫无心 2020-11-22 02:19

I learned how to use the comparable but I\'m having difficulty with the Comparator. I am having a error in my code:

Exception in thread \"main\" java.lang.C         


        
14条回答
  •  -上瘾入骨i
    2020-11-22 03:09

    Here is my answer for a simple comparator tool

    public class Comparator {
    public boolean isComparatorRunning  = false;
    public void compareTableColumns(List tableNames) {
        if(!isComparatorRunning) {
            isComparatorRunning = true;
            try {
                for (String schTableName : tableNames) {
                    Map schemaTableMap = ComparatorUtil.getSchemaTableMap(schTableName); 
                    Map primaryColMap = ComparatorUtil.getColumnMetadataMap(DbConnectionRepository.getConnectionOne(), schemaTableMap);
                    Map secondaryColMap = ComparatorUtil.getColumnMetadataMap(DbConnectionRepository.getConnectionTwo(), schemaTableMap);
                    ComparatorUtil.publishColumnInfoOutput("Comparing table : "+ schemaTableMap.get(CompConstants.TABLE_NAME));
                    compareColumns(primaryColMap, secondaryColMap);
                }
            } catch (Exception e) {
                ComparatorUtil.publishColumnInfoOutput("ERROR"+e.getMessage());
            }
            isComparatorRunning = false;
        }
    }
    
    public void compareColumns(Map primaryColMap, Map secondaryColMap) {
        try {
            boolean isEqual = true;
            for(Map.Entry entry : primaryColMap.entrySet()) {
                String columnName = entry.getKey();
                ColumnInfo primaryColInfo = entry.getValue();
                ColumnInfo secondaryColInfo = secondaryColMap.remove(columnName);
                if(secondaryColInfo == null) {
                    // column is not present in Secondary Environment
                    ComparatorUtil.publishColumnInfoOutput("ALTER", primaryColInfo);
                    isEqual = false;
                    continue;
                }
                if(!primaryColInfo.equals(secondaryColInfo)) {
                    isEqual = false;
                    // Column not equal in secondary env
                    ComparatorUtil.publishColumnInfoOutput("MODIFY", primaryColInfo);
                }
            }
            if(!secondaryColMap.isEmpty()) {
                isEqual = false;
                for(Map.Entry entry : secondaryColMap.entrySet()) {
                    // column is not present in Primary Environment
                    ComparatorUtil.publishColumnInfoOutput("DROP", entry.getValue());
                }
            }
    
            if(isEqual) {
                ComparatorUtil.publishColumnInfoOutput("--Exact Match");
            }
        } catch (Exception e) {
            ComparatorUtil.publishColumnInfoOutput("ERROR"+e.getMessage());
        }
    }
    
    public void compareTableColumnsValues(String primaryTableName, String primaryColumnNames, String primaryCondition, String primaryKeyColumn, 
            String secTableName, String secColumnNames, String secCondition, String secKeyColumn) {
        if(!isComparatorRunning) {
            isComparatorRunning = true;
            Connection conn1 = DbConnectionRepository.getConnectionOne();
            Connection conn2 = DbConnectionRepository.getConnectionTwo();
    
            String query1 = buildQuery(primaryTableName, primaryColumnNames, primaryCondition, primaryKeyColumn);
            String query2 = buildQuery(secTableName, secColumnNames, secCondition, secKeyColumn);
            try {
                Map> query1Data = executeAndRefactorData(conn1, query1, primaryKeyColumn);
                Map> query2Data = executeAndRefactorData(conn2, query2, secKeyColumn);
    
                for(Map.Entry> entry : query1Data.entrySet()) {
                    String key = entry.getKey();
                    Map value = entry.getValue();
                    Map secondaryValue = query2Data.remove(key);
                    if(secondaryValue == null) {
                        ComparatorUtil.publishColumnValuesInfoOutput("NO SUCH VALUE AVAILABLE IN SECONDARY DB "+ value.toString());
                        continue;
                    }
                    compareMap(value, secondaryValue, key);
                }
    
                if(!query2Data.isEmpty()) {
                    ComparatorUtil.publishColumnValuesInfoOutput("Extra Values in Secondary table "+ ((Map)query2Data.values()).values().toString());
                }
            } catch (Exception e) {
                ComparatorUtil.publishColumnValuesInfoOutput("ERROR"+e.getMessage());
            }
            isComparatorRunning = false;
        }
    }
    
    private void compareMap(Map primaryValues, Map secondaryValues, String columnIdentification) {
        for(Map.Entry entry : primaryValues.entrySet()) {
            String key = entry.getKey();
            Object value = entry.getValue();
            Object secValue = secondaryValues.get(key);
            if(value!=null && secValue!=null && !String.valueOf(value).equalsIgnoreCase(String.valueOf(secValue))) {
                ComparatorUtil.publishColumnValuesInfoOutput(columnIdentification+" : Secondary Table does not match value ("+ value +") for column ("+ key+")");
            }
            if(value==null && secValue!=null) {
                ComparatorUtil.publishColumnValuesInfoOutput(columnIdentification+" : Values not available in primary table for column "+ key);
            }
            if(value!=null && secValue==null) {
                ComparatorUtil.publishColumnValuesInfoOutput(columnIdentification+" : Values not available in Secondary table for column "+ key);
            }
        }
    }
    
    private String buildQuery(String tableName, String column, String condition, String keyCol) {
        if(!"*".equalsIgnoreCase(column)) {
            String[] keyColArr = keyCol.split(",");
            for(String key: keyColArr) {
                if(!column.contains(key.trim())) {
                    column+=","+key.trim();
                }
            }
        }
        StringBuilder queryBuilder = new StringBuilder();
        queryBuilder.append("select "+column+" from "+ tableName);
        if(!ComparatorUtil.isNullorEmpty(condition)) {
            queryBuilder.append(" where 1=1 and "+condition);
        }
        return queryBuilder.toString();
    }
    
    private Map> executeAndRefactorData(Connection connection, String query, String keyColumn) {
        Map> result = new HashMap>();
        try {
            PreparedStatement preparedStatement = connection.prepareStatement(query);
            ResultSet resultSet = preparedStatement.executeQuery();
            resultSet.setFetchSize(1000);
            if (resultSet != null && !resultSet.isClosed()) {
                while (resultSet.next()) {
                    Map columnValueDetails = new HashMap();
                    int columnCount = resultSet.getMetaData().getColumnCount();
                    for (int i=1; i<=columnCount; i++) {
                        String columnName = String.valueOf(resultSet.getMetaData().getColumnName(i));
                        Object columnValue = resultSet.getObject(columnName);
                        columnValueDetails.put(columnName, columnValue);
                    }
                    String[] keys = keyColumn.split(",");
                    String newKey = "";
                    for(int j=0; j

    }

    Utility Tool for the same

    public class ComparatorUtil {
    
    public static Map getSchemaTableMap(String tableNameWithSchema) {
        if(isNullorEmpty(tableNameWithSchema)) {
            return null;
        }
        Map result = new LinkedHashMap<>();
        int index = tableNameWithSchema.indexOf(".");
        String schemaName = tableNameWithSchema.substring(0, index);
        String tableName = tableNameWithSchema.substring(index+1);
        result.put(CompConstants.SCHEMA_NAME, schemaName);
        result.put(CompConstants.TABLE_NAME, tableName);
        return result;
    }
    
    public static Map getColumnMetadataMap(Connection conn, Map schemaTableMap) {
        try {
            String schemaName = schemaTableMap.get(CompConstants.SCHEMA_NAME);
            String tableName = schemaTableMap.get(CompConstants.TABLE_NAME);
            ResultSet resultSetConnOne = conn.getMetaData().getColumns(null, schemaName, tableName, null);
            Map resultSetTwoColInfo = getColumnInfo(schemaName, tableName, resultSetConnOne);
            return resultSetTwoColInfo;
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return null;
    }
    
    /* Number Type mapping
     * 12-----VARCHAR
     * 3-----DECIMAL
     * 93-----TIMESTAMP
     * 1111-----OTHER
    */
    public static Map getColumnInfo(String schemaName, String tableName, ResultSet columns) {
        try {
            Map tableColumnInfo = new LinkedHashMap();
            while (columns.next()) {
                ColumnInfo columnInfo = new ColumnInfo();
                columnInfo.setSchemaName(schemaName);
                columnInfo.setTableName(tableName);
                columnInfo.setColumnName(columns.getString("COLUMN_NAME"));
                columnInfo.setDatatype(columns.getString("DATA_TYPE"));
                columnInfo.setColumnsize(columns.getString("COLUMN_SIZE"));
                columnInfo.setDecimaldigits(columns.getString("DECIMAL_DIGITS"));
                columnInfo.setIsNullable(columns.getString("IS_NULLABLE"));
                tableColumnInfo.put(columnInfo.getColumnName(), columnInfo);
            }
            return tableColumnInfo;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }
    
    public static boolean isNullOrEmpty(Object obj) {
        if (obj == null)
            return true;
        if (String.valueOf(obj).equalsIgnoreCase("NULL")) 
            return true;
        if (obj.toString().trim().length() == 0)
            return true;
        return false;
    }
    
    
    
    public static boolean isNullorEmpty(String str) {
        if(str == null)
            return true;
        if(str.trim().length() == 0) 
            return true;
        return false;
    }
    
    public static void publishColumnInfoOutput(String type, ColumnInfo columnInfo) {
        String str = "ALTER TABLE "+columnInfo.getSchemaName()+"."+columnInfo.getTableName();
        switch(type.toUpperCase()) {
            case "ALTER":
                if("NUMBER".equalsIgnoreCase(columnInfo.getDatatype()) || "DATE".equalsIgnoreCase(columnInfo.getDatatype())) {
                    str += " ADD ("+columnInfo.getColumnName()+" "+ columnInfo.getDatatype()+");";
                } else {
                    str += " ADD ("+columnInfo.getColumnName()+" "+ columnInfo.getDatatype() +"("+columnInfo.getColumnsize()+"));";
                }
                break;
            case "DROP":
                str += " DROP ("+columnInfo.getColumnName()+");";
                break;
            case "MODIFY":
                if("NUMBER".equalsIgnoreCase(columnInfo.getDatatype()) || "DATE".equalsIgnoreCase(columnInfo.getDatatype())) {
                    str += " MODIFY ("+columnInfo.getColumnName()+" "+ columnInfo.getDatatype()+");";
                } else {
                    str += " MODIFY ("+columnInfo.getColumnName()+" "+ columnInfo.getDatatype() +"("+columnInfo.getColumnsize()+"));";
                }
                break;
        }
        publishColumnInfoOutput(str);
    }
    
    public static Map allJdbcTypeName = null;
    
    public static Map getAllJdbcTypeNames() {
        Map result = new HashMap();
        if(allJdbcTypeName != null)
            return allJdbcTypeName;
        try {
            for (Field field : java.sql.Types.class.getFields()) {
                result.put((Integer) field.get(null), field.getName());
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return allJdbcTypeName=result;
    }
    
    public static String getStringPlaces(String[] attribs) {
        String params = "";
        for(int i=0; i

    }

    Column Info Class

    public class ColumnInfo {
    private String schemaName;
    private String tableName;
    private String columnName;
    private String datatype;
    private String columnsize;
    private String decimaldigits;
    private String isNullable;
    

提交回复
热议问题