NAME
Avatica::Client - Client for Apache Calcite Avatica
VERSION
version 0.003
AUTHOR
Alexey Stavrov <logioniz@ya.ru>
CONTRIBUTORS
Denis Ibaev <dionys@gmail.com>
Ivan Putintsev <uid@rydlab.ru>
uid66 <19481514+uid66@users.noreply.github.com>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2021 by Alexey Stavrov.
This is free software, licensed under:
The MIT (X11) License
SYNOPSIS
use Avatica::Client;
my $connection_id = 'number-or-uuid-or-any-string';
my $client = Avatica::Client->new(url => 'http://172.17.0.1:8765');
my ($res, $connection) = $client->open_connection($connection_id);
die "can't open connection: $connection->{message}" if !$res;
($res, my $prepare) = $client->prepare($connection_id, 'SELECT * FROM table WERE id = ? LIMIT 10');
die "can't prepare query: $prepare->{message}" if !$res;
my $statement = $prepare->get_statement;
my $statement_id = $statement->get_id;
my $signature = $statement->get_signature;
my $tv = Avatica::Client::Protocol::TypedValue->new;
$tv->set_number_value(1);
$tv->set_type(Avatica::Client::Protocol::Rep::LONG());
($res, my $execute) = $client->execute($connection_id, $statement_id, $signature, [$tv], 2);
die "can't execute: $execute->{message}" if !$res;
($res, my $fetch) = $client->fetch($connection_id, $statement_id, undef, 8);
die "can't fetch: $fetch->{message}" if !$res;
($res, my $close_state) = $client->close_statement($connection_id, $statement_id);
die "close statement error: $close_state->{message}" if !$res;
($res, $r) = $client->close_connection($connection_id);
die "close connection error: $r->{message}" if !$res;
DESCRIPTION
Client for Apache Calcite Avatica which based on HTTP and Google Protobuf.
new
Creates object of the Avatica::Client.
my $client = Avatica::Client->new(url => 'http://127.0.0.1:8765', max_retries => 10);
Parameters
url
URL to send request (required).
max_retries
Number of retires (default 3).
ua
HTTP::Tiny user agent.
open_connection
Open new connection.
my ($res, $connection) = $client->open_connection($connection_id);
Parameters
connection_id
Any generated string.
close_connection
Close connection.
my ($res, $data) = $client->close_connection($connection_id);
Parameters
connection_id
Connection id from open_connection call (required).
catalog
This request is used to fetch the available catalog names in the database.
my ($res, $catalog) = $client->catalog($connection_id);
Parameters
connection_id
Connection id from open_connection call (required).
columns
This request is used to fetch columns in the database given some optional filtering criteria.
my ($res, $columns) = $client->columns($connection_id, $catalog, $schema_pattern, $table_pattern, $column_pattern);
Parameters
connection_id
Connection id from open_connection call (required).
catalog
The name of a catalog to limit returned columns.
schema_pattern
A Java Pattern against schemas to limit returned columns.
table_pattern
A Java Pattern against table names to limit returned columns.
column_pattern
A Java Pattern against column names to limit returned columns.
database_property
This request is used to fetch all database properties.
my ($res, $prop) = $client->database_property($connection_id);
Parameters
connection_id
Connection id from open_connection call (required).
schemas
This request is used to fetch the schemas matching the provided criteria in the database.
my ($res, $schemas) = $client->schemas($connection_id, $catalog, $schema_pattern);
Parameters
connection_id
Connection id from open_connection call (required).
catalog
The name of the catalog to fetch the schema from.
schema_pattern
A Java pattern of schemas to fetch.
tables
This request is used to fetch the tables available in this database filtered by the provided criteria.
my ($res, $tables) = $client->tables($connection_id, $catalog, $schema_pattern, $table_pattern, $type_list);
Parameters
connection_id
Connection id from open_connection call (required).
catalog
The name of a catalog to restrict fetched tables.
schema_pattern
A Java Pattern representing schemas to include in fetched tables.
table_pattern
A Java Pattern representing table names to include in fetched tables.
type_list
A list of table types used to restrict fetched tables.
type_info
This request is used to fetch the types available in this database.
my ($res, $type_info) = $client->type_info($connection_id);
Parameters
connection_id
Connection id from open_connection call (required).
table_types
This request is used to fetch the table types available in this database.
my ($res, $table_types) = $client->table_types($connection_id);
Parameters
connection_id
Connection id from open_connection call (required).
connection_sync
This request is used to ensure that the client and server have a consistent view of the database properties. Returns the properties that were applied on the server.
my ($res, $connection_sync) = $client->connection_sync($connection_id, {
AutoCommit => 0,
ReadOnly => 0,
TransactionIsolation => 2,
Catalog => '',
Schema => ''
});
Parameters
connection_id
Connection id from open_connection call (required).
prop
This hash represents the properties for a given JDBC Connection. AutoCommit is a boolean denoting if AutoCommit is enabled for transactions. ReadOnly is a boolean denoting if a JDBC connection is read-only. TransactionIsolation is an integer which denotes the level of transactions isolation per the JDBC specification: 0 = No transactions. 1 = READ_UNCOMMITTED. 2 = READ_COMMITTED. 4 = REPEATABLE_READ. 8 = SERIALIZABLE. Catalog is the name of a catalog to use when fetching connection properties. Schema is the name of the schema to use when fetching connection properties.
commit
This request is used to issue a commit on the Connection in the Avatica server identified by the given ID.
my ($res, $commit) = $client->commit($connection_id);
Parameters
connection_id
Connection id from open_connection call (required).
rollback
This request is used to issue a rollback on the Connection in the Avatica server identified by the given ID.
my ($res, $rollback) = $client->rollback($connection_id);
Parameters
connection_id
Connection id from open_connection call (required).
create_statement
This request is used to create a new Statement in the Avatica server.
my ($res, $statement) = $client->create_statement($connection_id);
Parameters
connection_id
Connection id from open_connection call (required).
prepare_and_execute
This request is used as a short-hand for create a Statement and fetching the first batch of results in a single call without any parameter substitution.
my ($res, $result) = $client->prepare_and_execute($connection_id, $statement_id, $sql, $max_rows_total, $first_frame_max_size);
my ($res, $statement) = $client->create_statement($connection_id);
($res, my $result) = $client->prepare_and_execute($connection_id, $statement->get_statement_id, 'SELECT * FROM TABLE', undef, 100);
Parameters
connection_id
Connection id from open_connection call (required).
statement_id
The identifier of the created statement (required).
sql
A SQL statement (required).
max_rows_total
The maximum number of rows which this query should return.
first_frame_max_size
The maximum number of rows which should be included in the first Frame.
close_statement
This request is used to close the Statement object in the Avatica server identified by the given IDs.
my ($res, $result) = $client->close_statement($connection_id, $statement_id);
Parameters
connection_id
Connection id from open_connection call (required).
statement_id
The identifier of the statement to close (required).
prepare
This request is used to create create a new Statement with the given query in the Avatica server.
my ($res, $prepare) = $client->prepare($connection_id, $sql, $max_rows_total);
my ($res, $prepare) = $client->prepare($connection_id, 'SELECT * FROM TABLE');
Parameters
connection_id
Connection id from open_connection call (required).
sql
A SQL statement (required).
max_rows_total
The maximum number of rows which this query should return.
execute
This request is used to execute a PreparedStatement, optionally with values to bind to the parameters in the Statement.
my ($res, $execute) = $client->execute($connection_id, $statement_id, $signature, $param_values, $first_frame_max_size);
my ($res, $prepare) = $client->prepare($connection_id, 'SELECT * FROM table WHERE f1 = ? AND f2 = ?');
my $val1 = Avatica::Client::Protocol::TypedValue->new;
$val1->set_number_value(2);
$val1->set_type(Avatica::Client::Protocol::Rep::LONG());
my $val2 = Avatica::Client::Protocol::TypedValue->new;
$val2->set_number_value(2);
$val2->set_type(Avatica::Client::Protocol::Rep::LONG());
my ($res, $execute) = $client->execute($connection_id, $prepare->get_statement->get_id, $prepare->get_statement->get_signature, [$val1, $val2]);
Parameters
connection_id
Connection id from open_connection call (required).
statement_id
The identifier of the created statement (required).
signature
A Signature object for the statement (required).
param_values
The TypedValue for each parameter on the prepared statement.
first_frame_max_size
The maximum number of rows to return in the first Frame.
prepare_and_execute_batch
This request is used as short-hand to create a Statement and execute a batch of updates against that Statement.
my ($res, $result) = $client->prepare_and_execute_batch($connection_id, $statement_id, $sqls);
my ($res, $statement) = $client->create_statement($connection_id);
($res, my $result) = $client->prepare_and_execute_batch($connection_id, $statement->get_statement_id, [
'UPSERT INTO table(F1, F2) values (1, 2)',
'UPSERT INTO table(F1, F2) values (2, 3)',
'UPSERT INTO table(F1, F2) values (3, 4)'
]);
Parameters
connection_id
Connection id from open_connection call (required).
statement_id
The identifier of the created statement (required).
sqls
A list of SQL commands to execute a batch of updates (required).
execute_batch
This request is used to execute a batch of updates against a PreparedStatement.
my ($res, $result) = $client->execute_batch($connection_id, $statement_id, $rows);
my ($res, $prepare) = $client->prepare($connection_id, 'UPSERT INTO table(F1, F2) VALUES (1, ?)');
my $val1 = Avatica::Client::Protocol::TypedValue->new;
$val1->set_number_value(1);
$val1->set_type(Avatica::Client::Protocol::Rep::LONG());
my $val2 = Avatica::Client::Protocol::TypedValue->new;
$val2->set_number_value(2);
$val2->set_type(Avatica::Client::Protocol::Rep::LONG());
my ($res, $result) = $client->execute_batch($connection_id, $prepare->get_statement->get_id, [[$val1], [$val2]]);
Parameters
connection_id
Connection id from open_connection call (required).
statement_id
The identifier of the created statement (required).
rows
The list of the list of TypedValue for each parameter on the prepared statement (required).
fetch
This request is used to fetch a batch of rows from a Statement previously created.
my ($res, $result) = $client->fetch($connection_id, $statement_id, $offset, $frame_max_size);
Parameters
connection_id
Connection id from open_connection call.
statement_id
The identifier of the created statement.
offset
The positional offset into a result set to fetch.
frame_max_size
The maximum number of rows to return in the response. Negative means no limit.
sync_results
This request is used to reset a ResultSet's iterator to a specific offset in the Avatica server.
my ($res, $result) = $client->sync_results($connection_id, $statement_id, $state, $offset);
# fetch first 6 rows
($res, my $statement) = $client->create_statement($connection_id);
($res, my $execute) = $client->prepare_and_execute($connection_id, $statement->get_statement_id, 'SELECT * FROM table', undef, 2);
($res, my $fetch) = $client->fetch($connection_id, $statement_id, undef, 4);
# fetch again first 6 rows
my $state = Avatica::Client::Protocol::QueryState->new;
$state->set_type(0);
$state->set_sql('SELECT * FROM table');
$state->set_has_sql(1);
($res, my $sync) = $client->sync_results($connection_id, $statement_id, $state);
($res, $fetch) = $client->fetch($connection_id, $statement_id, undef, 6);
Parameters
connection_id
Connection id from open_connection call.
statement_id
The identifier of the created statement.
state
The QueryState object.
offset
The offset into the ResultSet to seek to.