| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- # -*- coding: utf-8 -*-
- from sqlalchemy import String, Integer, Boolean, ForeignKey
- from sqlalchemy.orm import Mapped, mapped_column, relationship
- from app.core.base_model import ModelMixin
- class DictTypeModel(ModelMixin):
- """
- 字典类型表
- """
- __tablename__: str = "sys_dict_type"
- __table_args__: dict[str, str] = ({'comment': '字典类型表'})
- dict_name: Mapped[str] = mapped_column(String(255), nullable=False, comment='字典名称')
- dict_type: Mapped[str] = mapped_column(String(255), nullable=False, unique=True, comment='字典类型')
-
- # 关系定义
- dict_data_list: Mapped[list["DictDataModel"]] = relationship("DictDataModel", back_populates="dict_type_obj", cascade="all, delete-orphan")
- class DictDataModel(ModelMixin):
- """
- 字典数据表
- """
- __tablename__: str = "sys_dict_data"
- __table_args__: dict[str, str] = ({'comment': '字典数据表'})
-
- dict_sort: Mapped[int] = mapped_column(Integer, nullable=False, default=0, comment='字典排序')
- dict_label: Mapped[str] = mapped_column(String(255), nullable=False, comment='字典标签')
- dict_value: Mapped[str] = mapped_column(String(255), nullable=False, comment='字典键值')
- css_class: Mapped[str | None] = mapped_column(String(255), nullable=True, comment='样式属性(其他样式扩展)')
- list_class: Mapped[str | None] = mapped_column(String(255), nullable=True, comment='表格回显样式')
- is_default: Mapped[bool] = mapped_column(Boolean, nullable=False, default=False, comment='是否默认(True是 False否)')
- dict_type: Mapped[str] = mapped_column(String(255), nullable=False, comment='字典类型')
-
- # 添加外键关系,同时保留dict_type字段用于业务查询
- dict_type_id: Mapped[int] = mapped_column(
- Integer,
- ForeignKey('sys_dict_type.id', ondelete='CASCADE'),
- nullable=False,
- comment='字典类型ID'
- )
-
- # 关系定义
- dict_type_obj: Mapped[DictTypeModel] = relationship("DictTypeModel", back_populates="dict_data_list")
|