feat(db): add nullable notes column to entry and month_entry
Free-text annotation up to 1024 chars. Nullable so existing rows need no backfill; an empty or whitespace-only input will be normalised to NULL in the service layer. Alembic batch_alter_table handles the SQLite table rebuild automatically. Refs #13 Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
parent
1eecfc3ae8
commit
4d40843e24
2 changed files with 44 additions and 0 deletions
|
|
@ -0,0 +1,42 @@
|
|||
"""add notes column to entry and month_entry
|
||||
|
||||
Revision ID: ec804bdf366d
|
||||
Revises: 03ebe3c07262
|
||||
Create Date: 2026-04-17 12:47:41.533978
|
||||
|
||||
"""
|
||||
from typing import Sequence, Union
|
||||
|
||||
from alembic import op
|
||||
import sqlalchemy as sa
|
||||
|
||||
|
||||
# revision identifiers, used by Alembic.
|
||||
revision: str = 'ec804bdf366d'
|
||||
down_revision: Union[str, Sequence[str], None] = '03ebe3c07262'
|
||||
branch_labels: Union[str, Sequence[str], None] = None
|
||||
depends_on: Union[str, Sequence[str], None] = None
|
||||
|
||||
|
||||
def upgrade() -> None:
|
||||
"""Upgrade schema."""
|
||||
# ### commands auto generated by Alembic - please adjust! ###
|
||||
with op.batch_alter_table('entry', schema=None) as batch_op:
|
||||
batch_op.add_column(sa.Column('notes', sa.String(length=1024), nullable=True))
|
||||
|
||||
with op.batch_alter_table('month_entry', schema=None) as batch_op:
|
||||
batch_op.add_column(sa.Column('notes', sa.String(length=1024), nullable=True))
|
||||
|
||||
# ### end Alembic commands ###
|
||||
|
||||
|
||||
def downgrade() -> None:
|
||||
"""Downgrade schema."""
|
||||
# ### commands auto generated by Alembic - please adjust! ###
|
||||
with op.batch_alter_table('month_entry', schema=None) as batch_op:
|
||||
batch_op.drop_column('notes')
|
||||
|
||||
with op.batch_alter_table('entry', schema=None) as batch_op:
|
||||
batch_op.drop_column('notes')
|
||||
|
||||
# ### end Alembic commands ###
|
||||
|
|
@ -51,6 +51,7 @@ class Entry(Base):
|
|||
)
|
||||
name: Mapped[str] = mapped_column(String(128), nullable=False)
|
||||
amount: Mapped[Decimal] = mapped_column(Numeric(10, 2), nullable=False)
|
||||
notes: Mapped[str | None] = mapped_column(String(1024), nullable=True)
|
||||
created_at: Mapped[datetime] = mapped_column(
|
||||
DateTime(timezone=True), server_default=func.now(), nullable=False
|
||||
)
|
||||
|
|
@ -117,6 +118,7 @@ class MonthEntry(Base):
|
|||
Numeric(10, 2), nullable=False, default=Decimal("0.00"),
|
||||
server_default="0.00",
|
||||
)
|
||||
notes: Mapped[str | None] = mapped_column(String(1024), nullable=True)
|
||||
origin_name: Mapped[str | None] = mapped_column(String(128), nullable=True)
|
||||
origin_planned: Mapped[Decimal | None] = mapped_column(
|
||||
Numeric(10, 2), nullable=True
|
||||
|
|
|
|||
Loading…
Reference in a new issue