701a919f4025_initial_schema.py 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. """initial_schema
  2. Revision ID: 701a919f4025
  3. Revises:
  4. Create Date: 2026-04-24 16:19:19.739900
  5. """
  6. from typing import Sequence, Union
  7. from alembic import op
  8. import sqlalchemy as sa
  9. # revision identifiers, used by Alembic.
  10. revision: str = '701a919f4025'
  11. down_revision: Union[str, Sequence[str], None] = None
  12. branch_labels: Union[str, Sequence[str], None] = None
  13. depends_on: Union[str, Sequence[str], None] = None
  14. def upgrade() -> None:
  15. # 1. Users Table
  16. op.create_table(
  17. 'users',
  18. sa.Column('id', sa.Integer(), autoincrement=True, primary_key=True),
  19. sa.Column('username', sa.String(length=100), nullable=False, unique=True),
  20. sa.Column('password_hash', sa.String(length=255), nullable=False),
  21. sa.Column('email', sa.String(length=255), nullable=True),
  22. sa.Column('search_limit', sa.String(length=10), server_default='50'),
  23. sa.Column('created_at', sa.TIMESTAMP(), server_default=sa.text('CURRENT_TIMESTAMP'))
  24. )
  25. # 2. Medical Profiles Table (EAV)
  26. op.create_table(
  27. 'user_health_profiles',
  28. sa.Column('id', sa.Integer(), autoincrement=True, primary_key=True),
  29. sa.Column('user_id', sa.Integer(), nullable=False),
  30. sa.Column('illness_health_condition_diet_dislikes_name', sa.String(length=100), nullable=False, server_default='None'),
  31. sa.Column('illness_health_condition_diet_dislikes_value', sa.String(length=255), nullable=False, server_default='None'),
  32. sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE')
  33. )
  34. # 3. Plates Table
  35. op.create_table(
  36. 'plates',
  37. sa.Column('id', sa.Integer(), autoincrement=True, primary_key=True),
  38. sa.Column('user_id', sa.Integer(), nullable=False),
  39. sa.Column('plate_name', sa.String(length=255), nullable=False),
  40. sa.Column('created_at', sa.TIMESTAMP(), server_default=sa.text('CURRENT_TIMESTAMP')),
  41. sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE')
  42. )
  43. # 4. Plate Items Table
  44. op.create_table(
  45. 'plate_items',
  46. sa.Column('id', sa.Integer(), autoincrement=True, primary_key=True),
  47. sa.Column('plate_id', sa.Integer(), nullable=False),
  48. sa.Column('product_code', sa.String(length=50), nullable=False),
  49. sa.Column('quantity_grams', sa.Float(), nullable=False),
  50. sa.ForeignKeyConstraint(['plate_id'], ['plates.id'], ondelete='CASCADE')
  51. )
  52. def downgrade() -> None:
  53. op.drop_table('plate_items')
  54. op.drop_table('plates')
  55. op.drop_table('user_health_profiles')
  56. op.drop_table('users')