model.py 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. # -*- coding: utf-8 -*-
  2. from typing import TYPE_CHECKING
  3. from sqlalchemy import String, Integer, ForeignKey
  4. from sqlalchemy.orm import relationship, Mapped, mapped_column
  5. from app.core.base_model import ModelMixin
  6. if TYPE_CHECKING:
  7. from app.api.v1.module_system.role.model import RoleModel
  8. from app.api.v1.module_system.user.model import UserModel
  9. class DeptModel(ModelMixin):
  10. """
  11. 部门模型
  12. """
  13. __tablename__: str = "sys_dept"
  14. __table_args__: dict[str, str] = ({'comment': '部门表'})
  15. name: Mapped[str] = mapped_column(String(40), nullable=False, comment="部门名称")
  16. order: Mapped[int] = mapped_column(Integer, nullable=False, default=999, comment="显示排序")
  17. code: Mapped[str | None] = mapped_column(String(20), nullable=True, index=True, comment="部门编码")
  18. leader: Mapped[str | None] = mapped_column(String(32), default=None, comment='部门负责人')
  19. phone: Mapped[str | None] = mapped_column(String(11), default=None, comment='手机')
  20. email: Mapped[str | None] = mapped_column(String(64), default=None, comment='邮箱')
  21. # 树形结构字段
  22. parent_id: Mapped[int | None] = mapped_column(
  23. Integer,
  24. ForeignKey("sys_dept.id", ondelete="SET NULL", onupdate="CASCADE"),
  25. default=None,
  26. index=True,
  27. comment="父级部门ID"
  28. )
  29. # 关联关系
  30. parent: Mapped["DeptModel | None"] = relationship(
  31. back_populates='children',
  32. remote_side="DeptModel.id",
  33. foreign_keys=[parent_id],
  34. uselist=False
  35. )
  36. children: Mapped[list["DeptModel"]] = relationship(
  37. back_populates='parent',
  38. foreign_keys=[parent_id],
  39. lazy="selectin"
  40. )
  41. roles: Mapped[list["RoleModel"]] = relationship(
  42. secondary="sys_role_depts",
  43. back_populates="depts",
  44. lazy="selectin"
  45. )
  46. users: Mapped[list["UserModel"]] = relationship(
  47. back_populates="dept",
  48. foreign_keys="UserModel.dept_id",
  49. lazy="selectin"
  50. )