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

com.nflabs.zeppelin.driver.hive11.HiveConnection Maven / Gradle / Ivy

There is a newer version: 0.3.3
Show newest version
package com.nflabs.zeppelin.driver.hive11;

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.Map;
import java.util.Properties;
import java.util.concurrent.Executor;

import org.apache.hadoop.hive.conf.HiveConf;
import org.apache.hadoop.hive.jdbc.HiveDatabaseMetaData;
import org.apache.hadoop.hive.jdbc.HivePreparedStatement;
import org.apache.hadoop.hive.jdbc.HiveStatement;
import org.apache.hadoop.hive.metastore.api.MetaException;
import org.apache.hadoop.hive.service.HiveClient;
import org.apache.hadoop.hive.service.HiveInterface;
import org.apache.hadoop.hive.service.HiveServer;
import org.apache.thrift.TException;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TProtocol;
import org.apache.thrift.transport.TSocket;
import org.apache.thrift.transport.TTransport;
import org.apache.thrift.transport.TTransportException;

public class HiveConnection implements java.sql.Connection{

	  private TTransport transport;
	  public HiveInterface client;
	  private boolean isClosed = true;
	  private SQLWarning warningChain = null;

	  private static final String URI_PREFIX = "jdbc:hive://";

	  public HiveConnection(HiveInterface client) throws SQLException {
		  this.client = client;
		  isClosed = false;
		  configureConnection();		  
	  }
	  
	  /**
	   * Create a connection to a local Hive
	   *
	   * @param hiveConf
	   * @throws SQLException
	   */
	  public HiveConnection(HiveConf hiveConf) throws SQLException {
	    try {
	      client = new HiveServer.HiveServerHandler(hiveConf);
	    } catch (MetaException e) {
	      throw new SQLException("Error accessing Hive metastore: "
	          + e.getMessage(), "08S01",e);
	    }
	    isClosed = false;
	    configureConnection();
	  }

	  /**
	   * TODO: - parse uri (use java.net.URI?).
	   */
	  public HiveConnection(String uri, Properties info) throws SQLException {
	    if (!uri.startsWith(URI_PREFIX)) {
	      throw new SQLException("Invalid URL: " + uri, "08S01");
	    }

	    // remove prefix
	    uri = uri.substring(URI_PREFIX.length());

	    // If uri is not specified, use local mode.
	    if (uri.isEmpty()) {
	      try {
	        client = new HiveServer.HiveServerHandler();
	      } catch (MetaException e) {
	        throw new SQLException("Error accessing Hive metastore: "
	            + e.getMessage(), "08S01",e);
	      }
	    } else {
	      // parse uri
	      // form: hostname:port/databasename
	      String[] parts = uri.split("/");
	      String[] hostport = parts[0].split(":");
	      int port = 10000;
	      String host = hostport[0];
	      try {
	        port = Integer.parseInt(hostport[1]);
	      } catch (Exception e) {
	      }
	      transport = new TSocket(host, port);
	      TProtocol protocol = new TBinaryProtocol(transport);
	      client = new HiveClient(protocol);
	      try {
	        transport.open();
	      } catch (TTransportException e) {
	        throw new SQLException("Could not establish connection to "
	            + uri + ": " + e.getMessage(), "08S01");
	      }
	    }
	    isClosed = false;
	    configureConnection();
	  }
	  
	 
	  public void abort(Executor executor) throws SQLException {
	    // JDK 1.7
	    throw new SQLException("Method not supported");
	  }

	  private void configureConnection() throws SQLException {
	    Statement stmt = createStatement();
	    stmt.execute(
	        "set hive.fetch.output.serde = org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe");
	    stmt.close();
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#clearWarnings()
	   */

	  public void clearWarnings() throws SQLException {
	    warningChain = null;
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#close()
	   */

	  public void close() throws SQLException {
	    if (!isClosed) {
	      try {
	        client.clean();
	      } catch (TException e) {
	        throw new SQLException("Error while cleaning up the server resources", e);
	      } finally {
	        isClosed = true;
	        if (transport != null) {
	          transport.close();
	        }
	      }
	    }
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#commit()
	   */

	  public void commit() throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#createArrayOf(java.lang.String,
	   * java.lang.Object[])
	   */

	  public Array createArrayOf(String arg0, Object[] arg1) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#createBlob()
	   */

	  public Blob createBlob() throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#createClob()
	   */

	  public Clob createClob() throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#createNClob()
	   */

	  public NClob createNClob() throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#createSQLXML()
	   */

	  public SQLXML createSQLXML() throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /**
	   * Creates a Statement object for sending SQL statements to the database.
	   * 
	   * @throws SQLException
	   *           if a database access error occurs.
	   * @see java.sql.Connection#createStatement()
	   */

	  public Statement createStatement() throws SQLException {
	    if (isClosed) {
	      throw new SQLException("Can't create Statement, connection is closed");
	    }
	    return new HiveStatement(client);
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#createStatement(int, int)
	   */

	  public Statement createStatement(int resultSetType, int resultSetConcurrency)
	      throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#createStatement(int, int, int)
	   */

	  public Statement createStatement(int resultSetType, int resultSetConcurrency,
	      int resultSetHoldability) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#createStruct(java.lang.String, java.lang.Object[])
	   */

	  public Struct createStruct(String typeName, Object[] attributes)
	      throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#getAutoCommit()
	   */

	  public boolean getAutoCommit() throws SQLException {
	    return true;
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#getCatalog()
	   */

	  public String getCatalog() throws SQLException {
	    return "";
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#getClientInfo()
	   */

	  public Properties getClientInfo() throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#getClientInfo(java.lang.String)
	   */

	  public String getClientInfo(String name) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#getHoldability()
	   */

	  public int getHoldability() throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#getMetaData()
	   */

	  public DatabaseMetaData getMetaData() throws SQLException {
	    return new HiveDatabaseMetaData(client);
	  }


	  public int getNetworkTimeout() throws SQLException {
	    // JDK 1.7
	    throw new SQLException("Method not supported");
	  }


	  public String getSchema() throws SQLException {
	    // JDK 1.7
	    throw new SQLException("Method not supported");
	  }
	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#getTransactionIsolation()
	   */

	  public int getTransactionIsolation() throws SQLException {
	    return Connection.TRANSACTION_NONE;
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#getTypeMap()
	   */

	  public Map> getTypeMap() throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#getWarnings()
	   */

	  public SQLWarning getWarnings() throws SQLException {
	    return warningChain;
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#isClosed()
	   */

	  public boolean isClosed() throws SQLException {
	    return isClosed;
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#isReadOnly()
	   */

	  public boolean isReadOnly() throws SQLException {
	    return false;
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#isValid(int)
	   */

	  public boolean isValid(int timeout) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#nativeSQL(java.lang.String)
	   */

	  public String nativeSQL(String sql) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#prepareCall(java.lang.String)
	   */

	  public CallableStatement prepareCall(String sql) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#prepareCall(java.lang.String, int, int)
	   */

	  public CallableStatement prepareCall(String sql, int resultSetType,
	      int resultSetConcurrency) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#prepareCall(java.lang.String, int, int, int)
	   */

	  public CallableStatement prepareCall(String sql, int resultSetType,
	      int resultSetConcurrency, int resultSetHoldability) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#prepareStatement(java.lang.String)
	   */

	  public PreparedStatement prepareStatement(String sql) throws SQLException {
	    return new HivePreparedStatement(client, sql);
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#prepareStatement(java.lang.String, int)
	   */

	  public PreparedStatement prepareStatement(String sql, int autoGeneratedKeys)
	      throws SQLException {
	    return new HivePreparedStatement(client, sql);
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#prepareStatement(java.lang.String, int[])
	   */

	  public PreparedStatement prepareStatement(String sql, int[] columnIndexes)
	      throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#prepareStatement(java.lang.String,
	   * java.lang.String[])
	   */

	  public PreparedStatement prepareStatement(String sql, String[] columnNames)
	      throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#prepareStatement(java.lang.String, int, int)
	   */

	  public PreparedStatement prepareStatement(String sql, int resultSetType,
	      int resultSetConcurrency) throws SQLException {
	    return new HivePreparedStatement(client, sql);
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#prepareStatement(java.lang.String, int, int, int)
	   */

	  public PreparedStatement prepareStatement(String sql, int resultSetType,
	      int resultSetConcurrency, int resultSetHoldability) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#releaseSavepoint(java.sql.Savepoint)
	   */

	  public void releaseSavepoint(Savepoint savepoint) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#rollback()
	   */

	  public void rollback() throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#rollback(java.sql.Savepoint)
	   */

	  public void rollback(Savepoint savepoint) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#setAutoCommit(boolean)
	   */

	  public void setAutoCommit(boolean autoCommit) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#setCatalog(java.lang.String)
	   */

	  public void setCatalog(String catalog) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#setClientInfo(java.util.Properties)
	   */

	  public void setClientInfo(Properties properties)
	      throws SQLClientInfoException {
	    // TODO Auto-generated method stub
	    throw new SQLClientInfoException("Method not supported", null);
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#setClientInfo(java.lang.String, java.lang.String)
	   */

	  public void setClientInfo(String name, String value)
	      throws SQLClientInfoException {
	    // TODO Auto-generated method stub
	    throw new SQLClientInfoException("Method not supported", null);
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#setHoldability(int)
	   */

	  public void setHoldability(int holdability) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  public void setNetworkTimeout(Executor executor, int milliseconds) throws SQLException {
	    // JDK 1.7
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#setReadOnly(boolean)
	   */

	  public void setReadOnly(boolean readOnly) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#setSavepoint()
	   */

	  public Savepoint setSavepoint() throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#setSavepoint(java.lang.String)
	   */

	  public Savepoint setSavepoint(String name) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  public void setSchema(String schema) throws SQLException {
	    // JDK 1.7
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#setTransactionIsolation(int)
	   */

	  public void setTransactionIsolation(int level) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Connection#setTypeMap(java.util.Map)
	   */

	  public void setTypeMap(Map> map) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  /*
	   * (non-Javadoc)
	   * 
	   * @see java.sql.Wrapper#isWrapperFor(java.lang.Class)
	   */

	  public boolean isWrapperFor(Class iface) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }

	  public  T unwrap(Class iface) throws SQLException {
	    // TODO Auto-generated method stub
	    throw new SQLException("Method not supported");
	  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy