upload project source code

This commit is contained in:
2026-04-30 18:49:43 +08:00
commit 9b394ba682
2277 changed files with 660945 additions and 0 deletions

View File

@@ -0,0 +1,47 @@
# -*- 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")