com.facebook.presto.tests.jdbc.PreparedStatements Maven / Gradle / Ivy
The newest version!
/*
* Licensed 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.facebook.presto.tests.jdbc;
import com.facebook.airlift.log.Logger;
import io.prestodb.tempto.ProductTest;
import io.prestodb.tempto.Requirement;
import io.prestodb.tempto.RequirementsProvider;
import io.prestodb.tempto.Requires;
import io.prestodb.tempto.configuration.Configuration;
import io.prestodb.tempto.query.QueryResult;
import org.testng.annotations.Test;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.sql.Connection;
import java.sql.Date;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Timestamp;
import static com.facebook.presto.tests.TestGroups.JDBC;
import static com.facebook.presto.tests.TestGroups.SIMBA_JDBC;
import static com.facebook.presto.tests.hive.AllSimpleTypesTableDefinitions.ALL_HIVE_SIMPLE_TYPES_TEXTFILE;
import static com.facebook.presto.tests.utils.JdbcDriverUtils.usingTeradataJdbcDriver;
import static io.prestodb.tempto.assertions.QueryAssert.Row.row;
import static io.prestodb.tempto.assertions.QueryAssert.assertThat;
import static io.prestodb.tempto.fulfillment.table.MutableTableRequirement.State.CREATED;
import static io.prestodb.tempto.fulfillment.table.MutableTablesState.mutableTablesState;
import static io.prestodb.tempto.fulfillment.table.TableRequirements.immutableTable;
import static io.prestodb.tempto.fulfillment.table.TableRequirements.mutableTable;
import static io.prestodb.tempto.query.QueryExecutor.defaultQueryExecutor;
import static io.prestodb.tempto.query.QueryExecutor.param;
import static io.prestodb.tempto.query.QueryExecutor.query;
import static java.sql.JDBCType.BIGINT;
import static java.sql.JDBCType.BOOLEAN;
import static java.sql.JDBCType.CHAR;
import static java.sql.JDBCType.DATE;
import static java.sql.JDBCType.DECIMAL;
import static java.sql.JDBCType.DOUBLE;
import static java.sql.JDBCType.FLOAT;
import static java.sql.JDBCType.INTEGER;
import static java.sql.JDBCType.REAL;
import static java.sql.JDBCType.SMALLINT;
import static java.sql.JDBCType.TIMESTAMP;
import static java.sql.JDBCType.TINYINT;
import static java.sql.JDBCType.VARBINARY;
import static java.sql.JDBCType.VARCHAR;
public class PreparedStatements
extends ProductTest
{
private static final Logger LOGGER = Logger.get(PreparedStatements.class);
private static final String TABLE_NAME = "textfile_all_types";
private static final String TABLE_NAME_MUTABLE = "all_types_table_name";
private static final String INSERT_SQL = "INSERT INTO %s VALUES(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)";
private static final String SELECT_STAR_SQL = "SELECT * FROM %s";
private static class ImmutableAllTypesTable
implements RequirementsProvider
{
@Override
public Requirement getRequirements(Configuration configuration)
{
return immutableTable(ALL_HIVE_SIMPLE_TYPES_TEXTFILE);
}
}
private static class MutableAllTypesTable
implements RequirementsProvider
{
@Override
public Requirement getRequirements(Configuration configuration)
{
return mutableTable(ALL_HIVE_SIMPLE_TYPES_TEXTFILE, TABLE_NAME_MUTABLE, CREATED);
}
}
@Test(groups = {JDBC, SIMBA_JDBC})
@Requires(ImmutableAllTypesTable.class)
public void preparedSelectApi()
{
if (usingTeradataJdbcDriver(connection())) {
String selectSql = "SELECT c_int FROM " + TABLE_NAME + " WHERE c_int = ?";
final int testValue = 2147483647;
assertThat(query(selectSql, param(INTEGER, testValue))).containsOnly(row(testValue));
assertThat(query(selectSql, param(INTEGER, null))).hasNoRows();
assertThat(query(selectSql, param(INTEGER, 2))).hasNoRows();
}
else {
LOGGER.warn("preparedSelectApi() only applies to TeradataJdbcDriver");
}
}
@Test(groups = {JDBC, SIMBA_JDBC})
@Requires(ImmutableAllTypesTable.class)
public void preparedSelectSql()
throws SQLException
{
if (usingTeradataJdbcDriver(connection())) {
String prepareSql = "PREPARE ps1 from SELECT c_int FROM " + TABLE_NAME + " WHERE c_int = ?";
final int testValue = 2147483647;
String executeSql = "EXECUTE ps1 using ";
Statement statement = connection().createStatement();
statement.execute(prepareSql);
assertThat(QueryResult.forResultSet(statement.executeQuery(executeSql + testValue)))
.containsOnly(row(testValue));
assertThat(QueryResult.forResultSet(statement.executeQuery(executeSql + "NULL")))
.hasNoRows();
assertThat(QueryResult.forResultSet(statement.executeQuery(executeSql + 2)))
.hasNoRows();
}
else {
LOGGER.warn("preparedSelectSql() only applies to TeradataJdbcDriver");
}
}
@Test(groups = {JDBC, SIMBA_JDBC})
@Requires(MutableAllTypesTable.class)
public void preparedInsertVarbinaryApi()
{
if (usingTeradataJdbcDriver(connection())) {
String tableNameInDatabase = mutableTablesState().get(TABLE_NAME_MUTABLE).getNameInDatabase();
String insertSqlWithTable = String.format(INSERT_SQL, tableNameInDatabase);
String selectSqlWithTable = String.format(SELECT_STAR_SQL, tableNameInDatabase);
defaultQueryExecutor().executeQuery(
insertSqlWithTable,
param(TINYINT, null),
param(SMALLINT, null),
param(INTEGER, null),
param(BIGINT, null),
param(FLOAT, null),
param(DOUBLE, null),
param(DECIMAL, null),
param(DECIMAL, null),
param(TIMESTAMP, null),
param(DATE, null),
param(VARCHAR, null),
param(VARCHAR, null),
param(CHAR, null),
param(BOOLEAN, null),
param(VARBINARY, new byte[] {0, 1, 2, 3, 0, 42, -7 }));
QueryResult result = defaultQueryExecutor().executeQuery(selectSqlWithTable);
assertColumnTypes(result);
assertThat(result).containsOnly(
row(null, null, null, null, null, null, null, null, null, null, null, null, null, null,
new byte[] {0, 1, 2, 3, 0, 42, -7 }));
}
else {
LOGGER.warn("preparedInsertVarbinaryApi() only applies to TeradataJdbcDriver");
}
}
@Test(groups = {JDBC, SIMBA_JDBC})
@Requires(MutableAllTypesTable.class)
public void preparedInsertApi()
{
if (usingTeradataJdbcDriver(connection())) {
String tableNameInDatabase = mutableTablesState().get(TABLE_NAME_MUTABLE).getNameInDatabase();
String insertSqlWithTable = String.format(INSERT_SQL, tableNameInDatabase);
String selectSqlWithTable = String.format(SELECT_STAR_SQL, tableNameInDatabase);
query(
insertSqlWithTable,
param(TINYINT, 127),
param(SMALLINT, 32767),
param(INTEGER, 2147483647),
param(BIGINT, new BigInteger("9223372036854775807")),
param(FLOAT, Float.valueOf("123.345")),
param(DOUBLE, 234.567),
param(DECIMAL, BigDecimal.valueOf(345)),
param(DECIMAL, BigDecimal.valueOf(345.678)),
param(TIMESTAMP, Timestamp.valueOf("2015-05-10 12:15:35")),
param(DATE, Date.valueOf("2015-05-10")),
param(VARCHAR, "ala ma kota"),
param(VARCHAR, "ala ma kot"),
param(CHAR, " ala ma"),
param(BOOLEAN, Boolean.TRUE),
param(VARBINARY, new byte[] {0, 1, 2, 3, 0, 42, -7 }));
query(
insertSqlWithTable,
param(TINYINT, 1),
param(SMALLINT, 2),
param(INTEGER, 3),
param(BIGINT, 4),
param(FLOAT, Float.valueOf("5.6")),
param(DOUBLE, 7.8),
param(DECIMAL, BigDecimal.valueOf(91)),
param(DECIMAL, BigDecimal.valueOf(2.3)),
param(TIMESTAMP, Timestamp.valueOf("2012-05-10 1:35:15")),
param(DATE, Date.valueOf("2014-03-10")),
param(VARCHAR, "abc"),
param(VARCHAR, "def"),
param(CHAR, " ghi"),
param(BOOLEAN, Boolean.FALSE),
param(VARBINARY, new byte[] {0, 1, 2, 3, 0, 42, -7 }));
query(
insertSqlWithTable,
param(TINYINT, null),
param(SMALLINT, null),
param(INTEGER, null),
param(BIGINT, null),
param(FLOAT, null),
param(DOUBLE, null),
param(DECIMAL, null),
param(DECIMAL, null),
param(TIMESTAMP, null),
param(DATE, null),
param(VARCHAR, null),
param(VARCHAR, null),
param(CHAR, null),
param(BOOLEAN, null),
param(VARBINARY, null));
QueryResult result = query(selectSqlWithTable);
assertColumnTypes(result);
assertThat(result).containsOnly(
row(
127,
32767,
2147483647,
new Long("9223372036854775807"),
Float.valueOf("123.345"),
234.567,
BigDecimal.valueOf(345),
new BigDecimal("345.67800"),
Timestamp.valueOf("2015-05-10 12:15:35"),
Date.valueOf("2015-05-10"),
"ala ma kota",
"ala ma kot",
" ala ma",
Boolean.TRUE,
new byte[] {0, 1, 2, 3, 0, 42, -7 }),
row(
1,
2,
3,
4L,
Float.valueOf("5.6"),
7.8,
BigDecimal.valueOf(91),
BigDecimal.valueOf(2.3),
Timestamp.valueOf("2012-05-10 1:35:15"),
Date.valueOf("2014-03-10"),
"abc",
"def",
" ghi",
Boolean.FALSE,
new byte[] {0, 1, 2, 3, 0, 42, -7 }),
row(null, null, null, null, null, null, null, null, null, null, null, null, null, null, null));
}
else {
LOGGER.warn("preparedInsertApi() only applies to TeradataJdbcDriver");
}
}
@Test(groups = {JDBC, SIMBA_JDBC})
@Requires(MutableAllTypesTable.class)
public void preparedInsertSql()
throws SQLException
{
if (usingTeradataJdbcDriver(connection())) {
String tableNameInDatabase = mutableTablesState().get(TABLE_NAME_MUTABLE).getNameInDatabase();
String insertSqlWithTable = "PREPARE ps1 from " + String.format(INSERT_SQL, tableNameInDatabase);
String selectSqlWithTable = String.format(SELECT_STAR_SQL, tableNameInDatabase);
String executeSql = "EXECUTE ps1 using ";
Statement statement = connection().createStatement();
statement.execute(insertSqlWithTable);
statement.execute(executeSql +
"cast(127 as tinyint), " +
"cast(32767 as smallint), " +
"2147483647, " +
"9223372036854775807, " +
"cast(123.345 as real), " +
"cast(234.567 as double), " +
"cast(345 as decimal(10)), " +
"cast(345.678 as decimal(10,5)), " +
"timestamp '2015-05-10 12:15:35', " +
"date '2015-05-10', " +
"'ala ma kota', " +
"'ala ma kot', " +
"cast('ala ma' as char(10)), " +
"true, " +
"X'00010203002AF9'");
statement.execute(executeSql +
"cast(1 as tinyint), " +
"cast(2 as smallint), " +
"3, " +
"4, " +
"cast(5.6 as real), " +
"cast(7.8 as double), " +
"cast(9 as decimal(10)), " +
"cast(2.3 as decimal(10,5)), " +
"timestamp '2012-05-10 1:35:15', " +
"date '2014-03-10', " +
"'abc', " +
"'def', " +
"cast('ghi' as char(10)), " +
"false, " +
"varbinary 'jkl'");
statement.execute(executeSql +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null");
QueryResult result = query(selectSqlWithTable);
assertColumnTypes(result);
assertThat(result).containsOnly(
row(
127,
32767,
2147483647,
new Long("9223372036854775807"),
Float.valueOf("123.345"),
234.567,
BigDecimal.valueOf(345),
new BigDecimal("345.67800"),
Timestamp.valueOf("2015-05-10 12:15:35"),
Date.valueOf("2015-05-10"),
"ala ma kota",
"ala ma kot",
"ala ma ",
Boolean.TRUE,
new byte[] {0, 1, 2, 3, 0, 42, -7 }),
row(
1,
2,
3,
4,
Float.valueOf("5.6"),
7.8,
BigDecimal.valueOf(9),
new BigDecimal("2.30000"),
Timestamp.valueOf("2012-05-10 1:35:15"),
Date.valueOf("2014-03-10"),
"abc",
"def",
"ghi ",
Boolean.FALSE,
"jkl".getBytes()),
row(null, null, null, null, null, null, null, null, null, null, null, null, null, null, null));
}
else {
LOGGER.warn("preparedInsertSql() only applies to TeradataJdbcDriver");
}
}
@Test(groups = {JDBC, SIMBA_JDBC})
@Requires(MutableAllTypesTable.class)
public void preparedInsertVarbinarySql()
throws SQLException
{
if (usingTeradataJdbcDriver(connection())) {
String tableNameInDatabase = mutableTablesState().get(TABLE_NAME_MUTABLE).getNameInDatabase();
String insertSqlWithTable = "PREPARE ps1 from " + String.format(INSERT_SQL, tableNameInDatabase);
String selectSqlWithTable = String.format(SELECT_STAR_SQL, tableNameInDatabase);
String executeSql = "EXECUTE ps1 using ";
Statement statement = connection().createStatement();
statement.execute(insertSqlWithTable);
statement.execute(executeSql +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"null, " +
"X'00010203002AF9'");
QueryResult result = query(selectSqlWithTable);
assertColumnTypes(result);
assertThat(result).containsOnly(
row(null, null, null, null, null, null, null, null, null, null, null, null, null, null,
new byte[] {0, 1, 2, 3, 0, 42, -7 }));
}
else {
LOGGER.warn("preparedInsertVarbinarySql() only applies to TeradataJdbcDriver");
}
}
private void assertColumnTypes(QueryResult queryResult)
{
assertThat(queryResult).hasColumns(
TINYINT,
SMALLINT,
INTEGER,
BIGINT,
REAL,
DOUBLE,
DECIMAL,
DECIMAL,
TIMESTAMP,
DATE,
VARCHAR,
VARCHAR,
CHAR,
BOOLEAN,
VARBINARY);
}
private Connection connection()
{
return defaultQueryExecutor().getConnection();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy