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

com.treasuredata.jdbc.TDPreparedStatement Maven / Gradle / Ivy

There is a newer version: 0.5.11
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License 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.treasuredata.jdbc;

import com.treasuredata.jdbc.command.CommandContext;
import com.treasure_data.model.Job;

import java.io.InputStream;
import java.io.Reader;
import java.math.BigDecimal;
import java.net.URL;
import java.sql.Array;
import java.sql.Blob;
import java.sql.Clob;
import java.sql.Date;
import java.sql.NClob;
import java.sql.ParameterMetaData;
import java.sql.PreparedStatement;
import java.sql.Ref;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.RowId;
import java.sql.SQLException;
import java.sql.SQLXML;
import java.sql.Time;
import java.sql.Timestamp;
import java.util.Calendar;
import java.util.HashMap;
import java.util.Map;
import java.util.logging.Logger;

public class TDPreparedStatement
        extends TDStatement
        implements PreparedStatement
{
    private static Logger LOG = Logger.getLogger(
            TDPreparedStatement.class.getName());

    private CommandContext context;
    private Map preparedParameters = new HashMap();

    public TDPreparedStatement(TDConnection conn, String sql)
            throws SQLException
    {
        super(conn);
        context = createCommandContext(sql);
    }

    CommandContext getContext()
    {
        return context;
    }

    Map getParams()
    {
        return preparedParameters;
    }

    public void clearParameters()
            throws SQLException
    {
        preparedParameters.clear();
    }

    public void addBatch()
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#clearBatch()");
    }

    public void clearBatch()
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#clearBatch()");
    }

    public boolean execute()
            throws SQLException
    {
        return executeQuery() != null;
    }

    public synchronized ResultSet executeQuery()
            throws SQLException
    {
        String sql = context.sql;
        if (sql.contains("?")) {
            sql = updateSql(sql, preparedParameters);
        }
        return executeQuery(sql);
    }

    String updateSql(final String sql, Map parameters)
    {
        StringBuffer newSql = new StringBuffer(sql);

        int paramLoc = 1;
        while (getCharIndexFromSqlByParamLocation(sql, '?', paramLoc) > 0) {
            // check the user has set the needs parameters
            if (parameters.containsKey(paramLoc)) {
                int tt = getCharIndexFromSqlByParamLocation(newSql.toString(), '?', 1);
                newSql.deleteCharAt(tt);
                newSql.insert(tt, parameters.get(paramLoc));
            }
            paramLoc++;
        }

        return newSql.toString();
    }

    private int getCharIndexFromSqlByParamLocation(final String sql,
            final char cchar, final int paramLoc)
    {
        boolean escaping = false;
        boolean quoted = false;
        int num = 0;
        for (int i = 0; i < sql.length(); i++) {
            if (escaping) {
                escaping = false;
                continue;
            }
            char c = sql.charAt(i);
            switch (c) {
            case '\\':
                escaping = true;
                break;
            case '\'':
                // record the count of char "'"
                quoted = !quoted;
                break;
            default:
                if (c == cchar && !quoted) {
                    num++;
                    if (num == paramLoc) {
                        return i;
                    }
                }
                break;
            }
        }
        return -1;
    }

    @Override
    public int[] executeBatch()
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#executeBatch()");
    }

    public int executeUpdate()
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#executeUpdate()");
    }

    public ResultSetMetaData getMetaData()
            throws SQLException
    {
        return null;
    }

    public ParameterMetaData getParameterMetaData()
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#getParameterMetaData()");
    }

    public void setArray(int i, Array x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setArray(int, Array)");
    }

    public void setAsciiStream(int i, InputStream in)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setAsciiStream(int, InputStream)");
    }

    public void setAsciiStream(int i, InputStream in, int length)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setAsciiStream(int, InputStream, int)");
    }

    public void setAsciiStream(int i, InputStream in, long length)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setAsciiStream(int, InputStream, long)");
    }

    public void setBigDecimal(int parameterIndex, BigDecimal x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setBigDecimal(int, BigDecimal)");
    }

    public void setBinaryStream(int i, InputStream x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setBinaryStream(int, InputStream)");
    }

    public void setBinaryStream(int i, InputStream in, int length)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setBinaryStream(int, InputStream, int)");
    }

    public void setBinaryStream(int i, InputStream in, long length)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setBinaryStream(int, InputStream, long)");
    }

    public void setBlob(int i, Blob x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setBlob(int, Blob)");
    }

    public void setBlob(int i, InputStream inputStream)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setBlob(int, InputStream)");
    }

    public void setBlob(int i, InputStream inputStream, long length)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setBlob(int, InputStream, long)");
    }

    public void setBoolean(int parameterIndex, boolean x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setBoolean(int, boolean)");
    }

    public void setByte(int i, byte x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setByte(int, byte)");
    }

    public void setBytes(int i, byte[] x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setBytes(int, byte[])");
    }

    public void setCharacterStream(int i, Reader reader)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setCharacterStream(int, Reader)");
    }

    public void setCharacterStream(int i, Reader reader, int length)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setCharacterStream(int, Reader, int)");
    }

    public void setCharacterStream(int i, Reader reader, long length)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setCharacterStream(int, Reader, long)");
    }

    public void setClob(int i, Clob x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setClob(int, Clob)");
    }

    public void setClob(int i, Reader reader)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setClob(int, Reader)");
    }

    public void setClob(int i, Reader reader, long length)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setClob(int, Reader, long)");
    }

    public void setDate(int i, Date x)
            throws SQLException
    {
        if (conn.getConfig().type == Job.Type.PRESTO) {
            preparedParameters.put(i, "DATE '" + x.toString() + "'");
        }
        else {
            throw new SQLException("Unsupported TDPreparedStatement#setDate(int, Date) is supported for Presto query only");
        }
    }

    public void setDate(int i, Date x, Calendar cal)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setDate(int, Date, Calender)");
    }

    public void setDouble(int i, double x)
            throws SQLException
    {
        preparedParameters.put(i, Double.toString(x));
    }

    public void setFloat(int i, float x)
            throws SQLException
    {
        preparedParameters.put(i, Float.toString(x));
    }

    public void setInt(int i, int x)
            throws SQLException
    {
        preparedParameters.put(i, Integer.toString(x));
    }

    public void setLong(int i, long x)
            throws SQLException
    {
        preparedParameters.put(i, Long.toString(x));
    }

    public void setNCharacterStream(int i, Reader value)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setNCharacterStream(int, Reader)");
    }

    public void setNCharacterStream(int i, Reader value, long length)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setNCharacterStream(int, Reader, long)");
    }

    public void setNClob(int i, NClob value)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setNClob(int, NClob)");
    }

    public void setNClob(int i, Reader reader)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setNClob(int, Reader)");
    }

    public void setNClob(int i, Reader reader, long length)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setNClob(int, Reader, long)");
    }

    public void setNString(int i, String value)
            throws SQLException
    {
        setString(i, value);
    }

    public void setNull(int i, int sqlType)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setNull(int, int)");
    }

    public void setNull(int i, int sqlType, String typeName)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setNull(int, int, String)");
    }

    public void setObject(int i, Object x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setObject(int, Object)");
    }

    public void setObject(int i, Object x, int targetSqlType)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setObject(int, Object, int)");
    }

    public void setObject(int i, Object x, int targetSqlType, int scale)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setObject(int, Object, int, int)");
    }

    public void setRef(int i, Ref x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setRef(int, Ref)");
    }

    public void setRowId(int i, RowId x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setRowId(int, RowId)");
    }

    public void setSQLXML(int i, SQLXML xmlObject)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setSQLXML(int, SQLXML)");
    }

    public void setShort(int i, short x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setShort(int, short)");
    }

    public void setString(int i, String x)
            throws SQLException
    {
        x = x.replace("'", "\\'");
        preparedParameters.put(i, "'" + x + "'");
    }

    public void setTime(int i, Time x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setTime(int, Time)");
    }

    public void setTime(int i, Time x, Calendar cal)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setTime(int, Time, Calendar)");
    }

    public void setTimestamp(int i, Timestamp x)
            throws SQLException
    {
        if (conn.getConfig().type == Job.Type.PRESTO) {
            preparedParameters.put(i, "TIMESTAMP '" + x.toString() + "'");
        }
        else {
            throw new SQLException("Unsupported TDPreparedStatement#setTimestamp(int, Timestamp) is supported for Presto query only");
        }
    }

    public void setTimestamp(int i, Timestamp x, Calendar cal)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setTimestamp(int, Timestamp, Calendar)");
    }

    public void setURL(int i, URL x)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setURL(int, URL)");
    }

    public void setUnicodeStream(int i, InputStream x, int length)
            throws SQLException
    {
        throw new SQLException("Unsupported TDPreparedStatement#setUnicodeStream(int, InputStream, int)");
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy