com.axibase.tsd.driver.jdbc.ext.AtsdStatement Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of atsd-jdbc Show documentation
Show all versions of atsd-jdbc Show documentation
JDBC driver for SQL API using
/*
* Copyright 2016 Axibase Corporation or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* https://www.axibase.com/atsd/axibase-apache-2.0.pdf
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package com.axibase.tsd.driver.jdbc.ext;
import java.sql.SQLException;
import com.axibase.tsd.driver.jdbc.logging.LoggingFacade;
import com.axibase.tsd.driver.jdbc.util.ExceptionsUtil;
import org.apache.calcite.avatica.AvaticaConnection;
import org.apache.calcite.avatica.AvaticaStatement;
import org.apache.calcite.avatica.Meta.Signature;
import org.apache.calcite.avatica.Meta.StatementHandle;
public class AtsdStatement extends AvaticaStatement {
private static final LoggingFacade logger = LoggingFacade.getLogger(AtsdStatement.class);
protected AtsdStatement(AvaticaConnection connection, StatementHandle statementHandle, int resultSetType,
int resultSetConcurrency, int resultSetHoldability) {
super(connection, statementHandle, resultSetType, resultSetConcurrency, resultSetHoldability);
if (logger.isTraceEnabled())
logger.trace("[AtsdStatement#new] " + this.handle.id);
}
protected AtsdStatement(AvaticaConnection connection, StatementHandle statementHandle, int resultSetType,
int resultSetConcurrency, int resultSetHoldability, Signature signature) {
super(connection, statementHandle, resultSetType, resultSetConcurrency, resultSetHoldability, signature);
if (logger.isTraceEnabled())
logger.trace("[AtsdStatement#new] " + this.handle.id);
}
@Override
protected void executeInternal(String sql) throws SQLException {
try {
super.executeInternal(sql);
} catch (SQLException e) {
throw ExceptionsUtil.unboxException(e);
}
}
/*
Method should close current result set and return true if another one can be fetched.
As we always use one result set, always return false;
*/
@Override
public boolean getMoreResults() throws SQLException {
if (openResultSet != null) {
openResultSet.close();
}
return false;
}
@Override
public synchronized void cancel() throws SQLException {
if (!this.cancelFlag.get()) {
final AtsdConnection atsdConnection = (AtsdConnection) this.connection;
final AtsdMeta meta = (AtsdMeta) atsdConnection.getMeta();
meta.cancelStatement(this.handle);
}
super.cancel();
if (logger.isTraceEnabled()) {
logger.trace("[AtsdStatement#cancel]");
}
}
@Override
public synchronized void close() throws SQLException {
super.close();
if (logger.isTraceEnabled())
logger.trace("[AtsdStatement#close] " + this.handle.id);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy