27 lines
1.2 KiB
Python
27 lines
1.2 KiB
Python
"""Fundamentals database model for caching fundamental data."""
|
|
|
|
import uuid
|
|
from datetime import datetime
|
|
|
|
from sqlalchemy import Float, String, DateTime
|
|
from sqlalchemy.dialects.postgresql import UUID
|
|
from sqlalchemy.orm import Mapped, mapped_column
|
|
|
|
from shared.models.base import Base, TimestampMixin
|
|
|
|
|
|
class Fundamentals(TimestampMixin, Base):
|
|
__tablename__ = "fundamentals"
|
|
|
|
id: Mapped[uuid.UUID] = mapped_column(
|
|
UUID(as_uuid=True), primary_key=True, default=uuid.uuid4
|
|
)
|
|
ticker: Mapped[str] = mapped_column(String(20), unique=True, nullable=False, index=True)
|
|
eps_ttm: Mapped[float | None] = mapped_column(Float, nullable=True)
|
|
pe_ratio: Mapped[float | None] = mapped_column(Float, nullable=True)
|
|
peg_ratio: Mapped[float | None] = mapped_column(Float, nullable=True)
|
|
revenue_growth_yoy: Mapped[float | None] = mapped_column(Float, nullable=True)
|
|
profit_margin: Mapped[float | None] = mapped_column(Float, nullable=True)
|
|
debt_to_equity: Mapped[float | None] = mapped_column(Float, nullable=True)
|
|
market_cap: Mapped[float | None] = mapped_column(Float, nullable=True)
|
|
fetched_at: Mapped[datetime] = mapped_column(DateTime(timezone=True), nullable=False)
|