| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- import enum
- from datetime import date, datetime, time
- from sqlalchemy import (
- BIGINT,
- JSON,
- Boolean,
- Date,
- DateTime,
- Float,
- Integer,
- String,
- Text,
- Time,
- )
- from sqlalchemy.orm import Mapped, mapped_column
- from app.core.base_model import ModelMixin, UserMixin
- class StatusEnum(enum.Enum):
- """状态枚举"""
- ACTIVE = "active"
- INACTIVE = "inactive"
- class DemoModel(ModelMixin, UserMixin):
- """
- 示例表 - 涵盖大多数常用数据类型
- """
- __tablename__: str = "gen_demo"
- __table_args__: dict[str, str] = {"comment": "示例表"}
- __loader_options__: list[str] = ["created_by", "updated_by"]
- # 字符串类型
- name: Mapped[str] = mapped_column(String(64), nullable=False, comment="名称")
- a: Mapped[int | None] = mapped_column(Integer, nullable=True, comment="整数")
- b: Mapped[int | None] = mapped_column(BIGINT, nullable=True, comment="大整数")
- c: Mapped[float | None] = mapped_column(Float, nullable=True, comment="浮点数")
- d: Mapped[bool] = mapped_column(Boolean, default=True, nullable=False, comment="布尔型")
- e: Mapped[date | None] = mapped_column(Date, nullable=True, comment="日期")
- f: Mapped[time | None] = mapped_column(Time, nullable=True, comment="时间")
- g: Mapped[datetime | None] = mapped_column(DateTime, nullable=True, comment="日期时间")
- h: Mapped[str | None] = mapped_column(Text, nullable=True, comment="长文本")
- i: Mapped[dict | None] = mapped_column(JSON, nullable=True, comment="元数据(JSON格式)")
|