com.vesoft.nebula.jdbc.NebulaConnection Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of nebula-jdbc Show documentation
Show all versions of nebula-jdbc Show documentation
The official JDBC connector for Nebula Graph.
The newest version!
/* Copyright (c) 2020 vesoft inc. All rights reserved.
*
* This source code is licensed under Apache 2.0 License.
*/
package com.vesoft.nebula.jdbc;
import com.vesoft.nebula.client.graph.NebulaPoolConfig;
import com.vesoft.nebula.client.graph.data.HostAddress;
import com.vesoft.nebula.client.graph.data.ResultSet;
import com.vesoft.nebula.client.graph.exception.AuthFailedException;
import com.vesoft.nebula.client.graph.exception.ClientServerIncompatibleException;
import com.vesoft.nebula.client.graph.exception.IOErrorException;
import com.vesoft.nebula.client.graph.exception.InvalidConfigException;
import com.vesoft.nebula.client.graph.exception.NotValidConnectionException;
import com.vesoft.nebula.client.graph.net.NebulaPool;
import com.vesoft.nebula.client.graph.net.Session;
import com.vesoft.nebula.jdbc.statement.NebulaPreparedStatementImpl;
import com.vesoft.nebula.jdbc.statement.NebulaStatementImpl;
import com.vesoft.nebula.jdbc.utils.ExceptionBuilder;
import com.vesoft.nebula.jdbc.utils.NebulaJdbcUrlParser;
import com.vesoft.nebula.jdbc.utils.NebulaPropertyKey;
import java.net.UnknownHostException;
import java.sql.Array;
import java.sql.Blob;
import java.sql.CallableStatement;
import java.sql.Clob;
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.NClob;
import java.sql.PreparedStatement;
import java.sql.SQLClientInfoException;
import java.sql.SQLException;
import java.sql.SQLWarning;
import java.sql.SQLXML;
import java.sql.Savepoint;
import java.sql.Statement;
import java.sql.Struct;
import java.util.List;
import java.util.Map;
import java.util.Properties;
import java.util.concurrent.Executor;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class NebulaConnection implements Connection {
private final Logger log = LoggerFactory.getLogger(this.getClass());
private Properties properties;
private Session nebulaSession;
private String graphSpace = null;
private boolean isClosed = false;
private NebulaPool nebulaPool;
protected NebulaConnection(String url, Properties properties) throws SQLException {
try {
this.properties = NebulaJdbcUrlParser.parse(url, properties);
} catch (Exception e) {
throw new SQLException(e);
}
this.graphSpace = properties.getProperty(NebulaPropertyKey.DBNAME.getKeyName());
initNebulaPool(url, properties);
// check whether access the given graph space successfully.
try {
this.nebulaSession =
nebulaPool.getSession(properties.getProperty(NebulaPropertyKey.USER.getKeyName()),
properties.getProperty(NebulaPropertyKey.PASSWORD.getKeyName()), true);
ResultSet result = nebulaSession.execute("use " + graphSpace);
if (result.isSucceeded()) {
this.graphSpace = graphSpace;
log.info(String.format("Access graph space [%s] succeeded", graphSpace));
} else {
throw new SQLException(String.format("Access graph space [%s] failed. Error code:" +
" %d, Error message: %s",
graphSpace, result.getErrorCode(), result.getErrorMessage()));
}
} catch (IOErrorException | AuthFailedException | NotValidConnectionException | ClientServerIncompatibleException e) {
throw new SQLException(e);
}
}
private void initNebulaPool(String url, Properties properties) throws SQLException {
int minConnsSize = (int) properties.getOrDefault(NebulaPropertyKey.MINCONNSSIZE, 0);
int maxConnsSize = (int) properties.getOrDefault(NebulaPropertyKey.MAXCONNSSIZE, 10);
int timeout = (int) properties.getOrDefault(NebulaPropertyKey.TIMEOUT, 0);
int idleTime = (int) properties.getOrDefault(NebulaPropertyKey.IDLETIME, 0);
int intervalIdle = (int) properties.getOrDefault(NebulaPropertyKey.INTERVALIDLE, -1);
int waitTime = (int) properties.getOrDefault(NebulaPropertyKey.WAITTIME, 0);
NebulaPoolConfig nebulaPoolConfig = new NebulaPoolConfig();
nebulaPoolConfig.setMinConnSize(minConnsSize);
nebulaPoolConfig.setMaxConnSize(maxConnsSize);
nebulaPoolConfig.setTimeout(timeout);
nebulaPoolConfig.setIdleTime(idleTime);
nebulaPoolConfig.setIntervalIdle(intervalIdle);
nebulaPoolConfig.setWaitTime(waitTime);
List addressList = NebulaJdbcUrlParser.getAddresses(url);
nebulaPool = new NebulaPool();
try {
long start = System.currentTimeMillis();
nebulaPool.init(addressList, nebulaPoolConfig);
long end = System.currentTimeMillis();
log.info("NebulaPool.init(addressList, nebulaPoolConfig) use " + (end - start) + " ms");
} catch (UnknownHostException | InvalidConfigException e) {
throw new SQLException(e);
}
}
public ResultSet execute(String nGql) throws SQLException {
this.checkClosed();
try {
return nebulaSession.execute(nGql);
} catch (IOErrorException e) {
throw new SQLException(e.getMessage());
}
}
private void checkClosed() throws SQLException {
if (this.isClosed()) {
throw new SQLException("Connection already closed.");
}
}
@Override
public void close() throws SQLException {
this.checkClosed();
this.nebulaSession.release();
this.isClosed = true;
this.nebulaPool.close();
log.info("JDBCConnection closed");
}
@Override
public boolean isClosed() throws SQLException {
return this.isClosed;
}
@Override
public Statement createStatement() throws SQLException {
this.checkClosed();
return new NebulaStatementImpl(this);
}
@Override
public Statement createStatement(int resultSetType, int resultSetConcurrency) throws SQLException {
log.info("You are calling method \"Statement createStatement(int resultSetType, int " +
"resultSetConcurrency)\", " +
"the supported type is [TYPE_SCROLL_INSENSITIVE] and the supported concurrency is" +
" [CONCUR_READ_ONLY]. " +
"That is, the method you call is the same as \"Statement createStatement()\". ");
return this.createStatement();
}
@Override
public Statement createStatement(int resultSetType, int resultSetConcurrency,
int resultSetHoldability) throws SQLException {
log.info("You are calling method \"Statement createStatement(int resultSetType, int " +
"resultSetConcurrency, int resultSetHoldability)\", " +
"the supported type is [TYPE_SCROLL_INSENSITIVE], " +
"the supported concurrency is [CONCUR_READ_ONLY]" +
"and the supported holdability is [CLOSE_CURSORS_AT_COMMIT]." +
"That is, the method you call is the same as \"Statement createStatement()\". ");
return this.createStatement();
}
@Override
public PreparedStatement prepareStatement(String rawNGQL) throws SQLException {
this.checkClosed();
return new NebulaPreparedStatementImpl(this, rawNGQL);
}
@Override
public PreparedStatement prepareStatement(String nGql, int resultSetType,
int resultSetConcurrency) throws SQLException {
log.info("You are calling method \"PreparedStatement prepareStatement(String nGql, int " +
"resultSetType, int resultSetConcurrency)\", " +
"the supported type is [TYPE_SCROLL_INSENSITIVE] and the supported concurrency is" +
" [CONCUR_READ_ONLY]. " +
"That is, the method you call is the same as \"PreparedStatement prepareStatement" +
"(String nGql)\". ");
return this.prepareStatement(nGql);
}
@Override
public PreparedStatement prepareStatement(String nGql, int resultSetType,
int resultSetConcurrency, int resultSetHoldability) throws SQLException {
log.info("You are calling method \"PreparedStatement prepareStatement(String nGql, int " +
"resultSetType, int resultSetConcurrency, int resultSetHoldability)\", " +
"the supported type is [TYPE_SCROLL_INSENSITIVE] and the supported concurrency is" +
" [CONCUR_READ_ONLY] " +
"and the supported holdability is [CLOSE_CURSORS_AT_COMMIT]. " +
"That is, the method you call is the same as \"PreparedStatement prepareStatement" +
"(String nGql)\". ");
return this.prepareStatement(nGql);
}
@Override
public String getSchema() throws SQLException {
return this.properties.getProperty(NebulaPropertyKey.DBNAME.getKeyName());
}
@Override
public Properties getClientInfo() throws SQLException {
return null;
}
@Override
public String getClientInfo(String name) throws SQLException {
return (String) (getClientInfo().getOrDefault(name, "null"));
}
@Override
public void setSchema(String schema) throws SQLException {
properties.setProperty(NebulaPropertyKey.DBNAME.getKeyName(), schema);
}
public Properties getConnectionConfig() {
return this.properties;
}
@Override
public PreparedStatement prepareStatement(String sql, int autoGeneratedKeys) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public PreparedStatement prepareStatement(String sql, int[] columnIndexes) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public PreparedStatement prepareStatement(String sql, String[] columnNames) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public CallableStatement prepareCall(String sql) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public CallableStatement prepareCall(String sql, int resultSetType, int resultSetConcurrency) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public CallableStatement prepareCall(String sql, int resultSetType, int resultSetConcurrency,
int resultSetHoldability) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public String nativeSQL(String sql) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public void setAutoCommit(boolean autoCommit) throws SQLException {
}
@Override
public boolean getAutoCommit() throws SQLException {
return false;
}
@Override
public void commit() throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public void rollback() throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public DatabaseMetaData getMetaData() throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public void setReadOnly(boolean readOnly) throws SQLException {
}
@Override
public boolean isReadOnly() throws SQLException {
return false;
}
@Override
public void setCatalog(String catalog) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public String getCatalog() throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public void setTransactionIsolation(int level) throws SQLException {
}
@Override
public int getTransactionIsolation() throws SQLException {
return Connection.TRANSACTION_NONE;
}
@Override
public SQLWarning getWarnings() throws SQLException {
return null;
}
@Override
public void clearWarnings() throws SQLException {
}
@Override
public Map> getTypeMap() throws SQLException {
return null;
}
@Override
public void setTypeMap(Map> map) throws SQLException {
}
@Override
public void setHoldability(int holdability) throws SQLException {
}
@Override
public int getHoldability() throws SQLException {
// CLOSE_CURSORS_AT_COMMIT
return 0;
}
@Override
public Savepoint setSavepoint() throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public Savepoint setSavepoint(String name) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public void rollback(Savepoint savepoint) throws SQLException {
}
@Override
public void releaseSavepoint(Savepoint savepoint) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public Clob createClob() throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public Blob createBlob() throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public NClob createNClob() throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public SQLXML createSQLXML() throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public boolean isValid(int timeout) throws SQLException {
if (timeout < 0) {
throw new SQLException("Timeout value mustn't be less 0");
}
if (isClosed()) {
return false;
}
Statement statement = null;
try {
statement = createStatement();
if (statement.execute("YIELD 1")) {
return true;
} else {
return false;
}
} finally {
if (statement != null) {
statement.close();
}
}
}
@Override
public void setClientInfo(String name, String value) throws SQLClientInfoException {
}
@Override
public void setClientInfo(Properties properties) throws SQLClientInfoException {
}
@Override
public Array createArrayOf(String typeName, Object[] elements) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public Struct createStruct(String typeName, Object[] attributes) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public void abort(Executor executor) throws SQLException {
this.close();
}
@Override
public void setNetworkTimeout(Executor executor, int milliseconds) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public int getNetworkTimeout() throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public T unwrap(Class iface) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
@Override
public boolean isWrapperFor(Class> iface) throws SQLException {
throw ExceptionBuilder.buildUnsupportedOperationException();
}
}