Giter Club home page Giter Club logo

aioduckdb's Introduction

aioduckdb: DuckDB for AsyncIO

aioduckdb provides a friendly, async interface to DuckDB databases. It has been ported from the original aiosqlite module.

It replicates the duckdb module, but with async versions of all the standard connection and cursor methods, plus context managers for automatically closing connections and cursors:

async with aioduckdb.connect(...) as db:
    await db.execute("INSERT INTO some_table ...")
    await db.commit()

    async with db.execute("SELECT * FROM some_table") as cursor:
        async for row in cursor:
            ...

It can also be used in the traditional, procedural manner:

db = await aioduckdb.connect(...)
cursor = await db.execute('SELECT * FROM some_table')
row = await cursor.fetchone()
rows = await cursor.fetchall()
await cursor.close()
await db.close()

Install

aioduckdb is compatible with Python 3.6 and newer. ~~You can install it from PyPI:~~ Not currently on PyPI.

Details

aioduckdb allows interaction with DuckDB databases on the main AsyncIO event loop without blocking execution of other coroutines while waiting for queries or data fetches. It does this by using a single, shared thread per connection. This thread executes all actions within a shared request queue to prevent overlapping actions.

Connection objects are proxies to the real connections, contain the shared execution thread, and provide context managers to handle automatically closing connections. Cursors are similarly proxies to the real cursors, and provide async iterators to query results.

License

aioduckdb is copyright Salvador Pardiñas, and licensed under the MIT license. I am providing code in this repository to you under an open source license. This is my personal repository; the license you receive to my code is from me and not from my employer. See the LICENSE file for details.

Big thanks to Amethyst Reese for the original aiosqlite repository.

aioduckdb's People

Contributors

adminiuga avatar amyreese avatar arlyon avatar cjrh avatar dark0ghost avatar dependabot[bot] avatar devilxd avatar dmitrypolo avatar grigi avatar hellocoldworld avatar kouta-kun avatar lew21 avatar lonami avatar mariano54 avatar mastergroosha avatar montag451 avatar nuno-andre avatar p4l1ly avatar pandaninjas avatar pyup-bot avatar shipmints avatar simonw avatar snawoot avatar spyrosroum avatar tat2grl85 avatar vexelnet avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.