model.py 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. # -*- coding: utf-8 -*-
  2. from sqlalchemy import String, Integer, Boolean, ForeignKey
  3. from sqlalchemy.orm import Mapped, mapped_column, relationship
  4. from app.core.base_model import ModelMixin
  5. class DictTypeModel(ModelMixin):
  6. """
  7. 字典类型表
  8. """
  9. __tablename__: str = "sys_dict_type"
  10. __table_args__: dict[str, str] = ({'comment': '字典类型表'})
  11. dict_name: Mapped[str] = mapped_column(String(255), nullable=False, comment='字典名称')
  12. dict_type: Mapped[str] = mapped_column(String(255), nullable=False, unique=True, comment='字典类型')
  13. # 关系定义
  14. dict_data_list: Mapped[list["DictDataModel"]] = relationship("DictDataModel", back_populates="dict_type_obj", cascade="all, delete-orphan")
  15. class DictDataModel(ModelMixin):
  16. """
  17. 字典数据表
  18. """
  19. __tablename__: str = "sys_dict_data"
  20. __table_args__: dict[str, str] = ({'comment': '字典数据表'})
  21. dict_sort: Mapped[int] = mapped_column(Integer, nullable=False, default=0, comment='字典排序')
  22. dict_label: Mapped[str] = mapped_column(String(255), nullable=False, comment='字典标签')
  23. dict_value: Mapped[str] = mapped_column(String(255), nullable=False, comment='字典键值')
  24. css_class: Mapped[str | None] = mapped_column(String(255), nullable=True, comment='样式属性(其他样式扩展)')
  25. list_class: Mapped[str | None] = mapped_column(String(255), nullable=True, comment='表格回显样式')
  26. is_default: Mapped[bool] = mapped_column(Boolean, nullable=False, default=False, comment='是否默认(True是 False否)')
  27. dict_type: Mapped[str] = mapped_column(String(255), nullable=False, comment='字典类型')
  28. # 添加外键关系,同时保留dict_type字段用于业务查询
  29. dict_type_id: Mapped[int] = mapped_column(
  30. Integer,
  31. ForeignKey('sys_dict_type.id', ondelete='CASCADE'),
  32. nullable=False,
  33. comment='字典类型ID'
  34. )
  35. # 关系定义
  36. dict_type_obj: Mapped[DictTypeModel] = relationship("DictTypeModel", back_populates="dict_data_list")