chrysopedia/alembic/versions/013_add_search_log.py
jlightner f64a0c1107 perf: Added SearchLog model, Alembic migration 013, Pydantic schemas, f…
- "backend/models.py"
- "backend/schemas.py"
- "backend/routers/search.py"
- "alembic/versions/013_add_search_log.py"

GSD-Task: S01/T01
2026-04-03 04:02:55 +00:00

31 lines
1.1 KiB
Python

"""Add search_log table for query analytics and popular searches.
Revision ID: 013_add_search_log
Revises: 012_multi_source_fmt
"""
from alembic import op
import sqlalchemy as sa
revision = "013_add_search_log"
down_revision = "012_multi_source_fmt"
branch_labels = None
depends_on = None
def upgrade() -> None:
op.create_table(
"search_log",
sa.Column("id", sa.Integer, primary_key=True, autoincrement=True),
sa.Column("query", sa.String(500), nullable=False),
sa.Column("scope", sa.String(50), nullable=False),
sa.Column("result_count", sa.Integer, nullable=False, server_default="0"),
sa.Column("created_at", sa.TIMESTAMP(), server_default=sa.func.now(), nullable=False),
)
op.create_index("ix_search_log_query", "search_log", ["query"])
op.create_index("ix_search_log_created_at", "search_log", ["created_at"])
def downgrade() -> None:
op.drop_index("ix_search_log_created_at", table_name="search_log")
op.drop_index("ix_search_log_query", table_name="search_log")
op.drop_table("search_log")