Skip to content

Latest commit

 

History

History
33 lines (22 loc) · 1.18 KB

readme.md

File metadata and controls

33 lines (22 loc) · 1.18 KB

trio-mongodb

Trio-mongodb was created because motor is coded in the most stupid + complex way possible I just cba

This creates a AsyncMongoClient that starts a seperate python process The process will use trio's to_sync to execute queries using pymongo

Ultimately, this results in a 100% nonblocking GIL bypassed trio lib for mongodb

Using threads only can potentially result in a massive slow down for your main process, code is provided for both, below is an example using process+threads

import trio

from trio_mongodb.process import AsyncMongoClient

async def main():
    client = AsyncMongoClient("mongodb://localhost:27017/", "your_database")
    collection = client.get_collection('your_collection')

    # Perform operations
    result = await collection.insert_one({"name": "Alice", "age": 30})
    print(f"Inserted ID: {result.inserted_id}")
    
    updateResult = await collection.update_one({"name": "Alice"}, {"$set": {"age": 31}})
    print(f"Updated count: {updateResult.modified_count} | Matched count: {updateResult.matched_count}")

    # Don't forget to close the client
    client.close()

if __name__ == "__main__":
    trio.run(main)