All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.akquinet.jbosscc.guttenbase.statements.SelectStatementCreator Maven / Gradle / Ivy

There is a newer version: 2.1.0
Show newest version
package de.akquinet.jbosscc.guttenbase.statements;

import de.akquinet.jbosscc.guttenbase.connector.DatabaseType;
import de.akquinet.jbosscc.guttenbase.meta.ColumnMetaData;
import de.akquinet.jbosscc.guttenbase.meta.TableMetaData;
import de.akquinet.jbosscc.guttenbase.repository.ConnectorRepository;
import java.sql.SQLException;
import java.sql.Types;

/**
 * Create SELECT statement for copying data.
 * 

*

* © 2012-2020 akquinet tech@spree *

* * @author M. Dahm */ public class SelectStatementCreator extends AbstractSelectStatementCreator { public SelectStatementCreator(final ConnectorRepository connectorRepository, final String connectorId) { super(connectorRepository, connectorId); } /** * Try to retrieve data in some deterministic order */ @Override protected String createOrderBy(final TableMetaData tableMetaData) throws SQLException { final StringBuilder buf = new StringBuilder("ORDER BY "); int columnsAdded = 0; // No BLOB or the like for ordering final boolean isOracle = DatabaseType.ORACLE.equals(tableMetaData.getDatabaseMetaData().getDatabaseType()); final int rangeFrom = isOracle ? Types.NULL : Types.LONGNVARCHAR; // Doesn't like LONG e.g. final int rangeTo = Types.JAVA_OBJECT; for (int i = 0; i < tableMetaData.getColumnCount(); i++) { final ColumnMetaData columnMetaData = tableMetaData.getColumnMetaData().get(i); final String columnName = _columnMapper.mapColumnName(columnMetaData, tableMetaData); final int jdbcType = columnMetaData.getColumnType(); if (jdbcType > rangeFrom && jdbcType < rangeTo) { buf.append(columnName).append(", "); columnsAdded++; } } if (columnsAdded > 0) { buf.setLength(buf.length() - 2); return buf.toString(); } else { return ""; } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy