Patterns for using Peewee ORM with DatabaseProxy and scoped connections/transactions. Use when setting up DatabaseProxy, managing connection_context/atomic blocks, or writing tests with SQLite.
/plugin marketplace add narumiruna/claude-marketplace/plugin install narumiruna-python-peewee-skills@narumiruna/claude-marketplaceThis skill inherits all available tools. When active, it can use any tool Claude has access to.
Use Peewee with DatabaseProxy and scoped connection/transaction patterns.
from peewee import DatabaseProxy, Model
db_proxy = DatabaseProxy()
class BaseModel(Model):
class Meta:
database = db_proxy
from peewee import SqliteDatabase
db = SqliteDatabase("app.db", pragmas={"foreign_keys": 1})
db_proxy.initialize(db)
with db_proxy.obj.connection_context():
rows = MyModel.select().limit(100)
with db_proxy.obj.atomic():
a.save()
b.save()
db = db_proxy.obj
with db.connection_context():
with db.atomic():
...
Use connection_context() for scoped connections (open/close).
Use atomic() for atomic writes (BEGIN/COMMIT/ROLLBACK).
import pytest
from peewee import SqliteDatabase
@pytest.fixture
def test_db(tmp_path):
db = SqliteDatabase(str(tmp_path / "test.db"))
db_proxy.initialize(db)
with db.connection_context():
db.create_tables([MyModel])
yield db
db.close()