Skip to main content

Databend Driver Python Binding

Project description

databend-driver

Build

cd bindings/python
maturin develop

Usage

Blocking

from databend_driver import BlockingDatabendClient

client = BlockingDatabendClient('databend+http://root:root@localhost:8000/?sslmode=disable')
conn = client.get_conn()
conn.exec(
    """
    CREATE TABLE test (
        i64 Int64,
        u64 UInt64,
        f64 Float64,
        s   String,
        s2  String,
        d   Date,
        t   DateTime
    )
    """
)
rows = conn.query_iter("SELECT * FROM test")
for row in rows:
    print(row.values())

Asyncio

import asyncio
from databend_driver import AsyncDatabendClient

async def main():
    client = AsyncDatabendClient('databend+http://root:root@localhost:8000/?sslmode=disable')
    conn = await client.get_conn()
    await conn.exec(
        """
        CREATE TABLE test (
            i64 Int64,
            u64 UInt64,
            f64 Float64,
            s   String,
            s2  String,
            d   Date,
            t   DateTime
        )
        """
    )
    rows = await conn.query_iter("SELECT * FROM test")
    async for row in rows:
        print(row.values())

asyncio.run(main())

Type Mapping

Databend Types

General Data Types

Databend Python
BOOLEAN bool
TINYINT int
SMALLINT int
INT int
BIGINT int
FLOAT float
DOUBLE float
DECIMAL decimal.Decimal
DATE datetime.date
TIMESTAMP datetime.datetime
VARCHAR str
BINARY bytes

Semi-Structured Data Types

Databend Python
ARRAY list
TUPLE tuple
MAP dict
VARIANT str
BITMAP str
GEOMETRY str

Note: VARIANT is a json encoded string. Example:

CREATE TABLE example (
    data VARIANT
);
INSERT INTO example VALUES ('{"a": 1, "b": "hello"}');
row = await conn.query_row("SELECT * FROM example limit 1;")
data = row.values()[0]
value = json.loads(data)
print(value)

APIs

AsyncDatabendClient

class AsyncDatabendClient:
    def __init__(self, dsn: str): ...
    async def get_conn(self) -> AsyncDatabendConnection: ...

AsyncDatabendConnection

class AsyncDatabendConnection:
    async def info(self) -> ConnectionInfo: ...
    async def version(self) -> str: ...
    async def exec(self, sql: str) -> int: ...
    async def query_row(self, sql: str) -> Row: ...
    async def query_iter(self, sql: str) -> RowIterator: ...
    async def stream_load(self, sql: str, data: list[list[str]]) -> ServerStats: ...

BlockingDatabendClient

class BlockingDatabendClient:
    def __init__(self, dsn: str): ...
    def get_conn(self) -> BlockingDatabendConnection: ...

BlockingDatabendConnection

class BlockingDatabendConnection:
    def info(self) -> ConnectionInfo: ...
    def version(self) -> str: ...
    def exec(self, sql: str) -> int: ...
    def query_row(self, sql: str) -> Row: ...
    def query_iter(self, sql: str) -> RowIterator: ...
    def stream_load(self, sql: str, data: list[list[str]]) -> ServerStats: ...

Row

class Row:
    def values(self) -> tuple: ...

RowIterator

class RowIterator:
    def schema(self) -> Schema: ...

    def __iter__(self) -> RowIterator: ...
    def __next__(self) -> Row: ...

    def __aiter__(self) -> RowIterator: ...
    async def __anext__(self) -> Row: ...

Field

class Field:
    @property
    def name(self) -> str: ...
    @property
    def data_type(self) -> str: ...

Schema

class Schema:
    def fields(self) -> list[Field]: ...

ServerStats

class ServerStats:
    @property
    def total_rows(self) -> int: ...
    @property
    def total_bytes(self) -> int: ...
    @property
    def read_rows(self) -> int: ...
    @property
    def read_bytes(self) -> int: ...
    @property
    def write_rows(self) -> int: ...
    @property
    def write_bytes(self) -> int: ...
    @property
    def running_time_ms(self) -> float: ...

ConnectionInfo

class ConnectionInfo:
    @property
    def handler(self) -> str: ...
    @property
    def host(self) -> str: ...
    @property
    def port(self) -> int: ...
    @property
    def user(self) -> str: ...
    @property
    def database(self) -> str | None: ...
    @property
    def warehouse(self) -> str | None: ...

Development

cd tests
make up
cd bindings/python
pipenv install --dev
pipenv run maturin develop
pipenv run behave tests/*

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

databend_driver-0.17.3-cp37-abi3-win_amd64.whl (4.8 MB view details)

Uploaded CPython 3.7+Windows x86-64

databend_driver-0.17.3-cp37-abi3-manylinux_2_28_aarch64.whl (4.6 MB view details)

Uploaded CPython 3.7+manylinux: glibc 2.28+ ARM64

databend_driver-0.17.3-cp37-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (5.0 MB view details)

Uploaded CPython 3.7+manylinux: glibc 2.17+ x86-64

databend_driver-0.17.3-cp37-abi3-macosx_11_0_arm64.whl (4.5 MB view details)

Uploaded CPython 3.7+macOS 11.0+ ARM64

databend_driver-0.17.3-cp37-abi3-macosx_10_12_x86_64.whl (4.8 MB view details)

Uploaded CPython 3.7+macOS 10.12+ x86-64

File details

Details for the file databend_driver-0.17.3-cp37-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for databend_driver-0.17.3-cp37-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 4a6feacb7d935f685db8884a68726cc666599ca92ee51d147d082a093367de96
MD5 2d79e4848d622da89c37cb9f0a87e987
BLAKE2b-256 f7cc1a1c09f6c22c6d5e45de2ce3f5f8c759247eba87e8d8004e850c7b89e66d

See more details on using hashes here.

File details

Details for the file databend_driver-0.17.3-cp37-abi3-manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for databend_driver-0.17.3-cp37-abi3-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 aed455f68c4f045d84c34519e9e2f0c54461e41ecdfc776baac06a9618a7771c
MD5 5974df0e31546f1f536f87a57e308204
BLAKE2b-256 347401320e9da1fae97a7e60230d482af50533d48a804f37fa2f3eee4c659cca

See more details on using hashes here.

File details

Details for the file databend_driver-0.17.3-cp37-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for databend_driver-0.17.3-cp37-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 841f79f30692d776b4992bfeb7cf0c93609182f07ab0c6d7d4db3739bd55ca99
MD5 078392077cf50c4901a591b84eb65c0d
BLAKE2b-256 66a29caf158a9945e6f2e8e5f9b7331ad2c6032c64dbac123bf43326d4627595

See more details on using hashes here.

File details

Details for the file databend_driver-0.17.3-cp37-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for databend_driver-0.17.3-cp37-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 23bf34b94225197bec38eb43c3f5aceea6bb98dde0d9a6c34fd75b7a820310be
MD5 f07ed0ea0ac459bcee0df6bf80f8118f
BLAKE2b-256 bcd988b55aca1045679e2aac4c299601481b1a98d2c4c07acaaca58ed2cf7d36

See more details on using hashes here.

File details

Details for the file databend_driver-0.17.3-cp37-abi3-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for databend_driver-0.17.3-cp37-abi3-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 cfe060647e9e6ce71fa2e311f0f53bfb8df0ba5dc6aa8a6af00eb64f7c2a5b28
MD5 1e4bf7067ae8c314ebbd7392c392268b
BLAKE2b-256 07b466033c1f8d3eb44e931409751a9cfea2697595bc23e8a66b8bd36d31732a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page