API¶
This part of the documentation covers basic classes of the driver: Client, Connection and others.
Client¶
-
class
clickhouse_driver.
Client
(*args, **kwargs)¶ Client for communication with the ClickHouse server. Single connection is established per each connected instance of the client.
Parameters: settings – Dictionary of settings that passed to every query. Defaults to None
(no additional settings). See all available settings in ClickHouse docs.Driver’s settings:
- insert_block_size – chunk size to split rows for
INSERT
. Defaults to1048576
. - strings_as_bytes – turns off string column encoding/decoding.
-
disconnect
()¶ Disconnects from the server.
-
execute
(query, params=None, with_column_types=False, external_tables=None, query_id=None, settings=None, types_check=False, columnar=False)¶ Executes query.
Establishes new connection if it wasn’t established yet. After query execution connection remains intact for next queries. If connection can’t be reused it will be closed and new connection will be created.
Parameters: - query – query that will be send to server.
- params – substitution parameters for SELECT queries and data for
INSERT queries. Data for INSERT can be list, tuple
or
GeneratorType
. Defaults toNone
(no parameters or data). - with_column_types – if specified column names and types will be
returned alongside with result.
Defaults to
False
. - external_tables – external tables to send.
Defaults to
None
(no external tables). - query_id – the query identifier. If no query id specified ClickHouse server will generate it.
- settings – dictionary of query settings.
Defaults to
None
(no additional settings). - types_check – enables type checking of data for INSERT queries.
Causes additional overhead. Defaults to
False
. - columnar – if specified the result will be returned in
column-oriented form.
Defaults to
False
(row-like form).
Returns: None
for INSERT queries.- If with_column_types=False: list of tuples with rows/columns.
- If with_column_types=True: tuple of 2 elements:
- The first element is list of tuples with rows/columns.
- The second element information is about columns: names and types.
-
execute_iter
(query, params=None, with_column_types=False, external_tables=None, query_id=None, settings=None, types_check=False)¶ New in version 0.0.14.
Executes SELECT query with results streaming. See, Streaming results.
Parameters: - query – query that will be send to server.
- params – substitution parameters for SELECT queries and data for
INSERT queries. Data for INSERT can be list, tuple
or
GeneratorType
. Defaults toNone
(no parameters or data). - with_column_types – if specified column names and types will be
returned alongside with result.
Defaults to
False
. - external_tables – external tables to send.
Defaults to
None
(no external tables). - query_id – the query identifier. If no query id specified ClickHouse server will generate it.
- settings – dictionary of query settings.
Defaults to
None
(no additional settings). - types_check – enables type checking of data for INSERT queries.
Causes additional overhead. Defaults to
False
.
Returns: IterQueryResult proxy.
-
execute_with_progress
(query, params=None, with_column_types=False, external_tables=None, query_id=None, settings=None, types_check=False)¶ Executes SELECT query with progress information. See, Selecting data with progress statistics.
Parameters: - query – query that will be send to server.
- params – substitution parameters for SELECT queries and data for
INSERT queries. Data for INSERT can be list, tuple
or
GeneratorType
. Defaults toNone
(no parameters or data). - with_column_types – if specified column names and types will be
returned alongside with result.
Defaults to
False
. - external_tables – external tables to send.
Defaults to
None
(no external tables). - query_id – the query identifier. If no query id specified ClickHouse server will generate it.
- settings – dictionary of query settings.
Defaults to
None
(no additional settings). - types_check – enables type checking of data for INSERT queries.
Causes additional overhead. Defaults to
False
.
Returns: ProgressQueryResult proxy.
- insert_block_size – chunk size to split rows for
Connection¶
-
class
clickhouse_driver.connection.
Connection
(host, port=None, database='default', user='default', password='', client_name='python-driver', connect_timeout=10, send_receive_timeout=300, sync_request_timeout=5, compress_block_size=1048576, compression=False, secure=False, verify=True, ssl_version=None, ca_certs=None, ciphers=None)¶ Represents connection between client and ClickHouse server.
Parameters: - host – host with running ClickHouse server.
- port – port ClickHouse server is bound to. Defaults to
9000
. - database – database connect to. Defaults to
'default'
. - user – database user. Defaults to
'default'
. - password – user’s password. Defaults to
''
(no password). - client_name – this name will appear in server logs.
Defaults to
'python-driver'
. - connect_timeout – timeout for establishing connection.
Defaults to
10
seconds. - send_receive_timeout – timeout for sending and receiving data.
Defaults to
300
seconds. - sync_request_timeout – timeout for server ping.
Defaults to
5
seconds. - compress_block_size – size of compressed block to send.
Defaults to
1048576
. - compression –
specifies whether or not use compression. Defaults to
False
. Possible choices:True
is equivalent to'lz4'
.'lz4'
.'lz4hc'
high-compression variant of'lz4'
.'zstd'
.
- secure – establish secure connection. Defaults to
False
. - verify – specifies whether a certificate is required and whether it
will be validated after connection.
Defaults to
True
. - ssl_version – see
ssl.wrap_socket()
docs. - ca_certs – see
ssl.wrap_socket()
docs. - ciphers – see
ssl.wrap_socket()
docs.
-
disconnect
()¶ Closes connection between server and client. Frees resources: e.g. closes socket.