mirror of
https://github.com/fastapi-practices/fastapi_best_architecture.git
synced 2025-08-17 22:21:35 +08:00
33 lines
1.5 KiB
Python
33 lines
1.5 KiB
Python
#!/usr/bin/env python3
|
||
# -*- coding: utf-8 -*-
|
||
from typing import Union
|
||
|
||
from sqlalchemy import ForeignKey, String
|
||
from sqlalchemy.orm import Mapped, mapped_column, relationship
|
||
|
||
from backend.app.models.base import Base, id_key
|
||
|
||
|
||
class Dept(Base):
|
||
"""部门表"""
|
||
|
||
__tablename__ = 'sys_dept'
|
||
|
||
id: Mapped[id_key] = mapped_column(init=False)
|
||
name: Mapped[str] = mapped_column(String(50), comment='部门名称')
|
||
level: Mapped[int] = mapped_column(default=0, comment='部门层级')
|
||
sort: Mapped[int] = mapped_column(default=0, comment='排序')
|
||
leader: Mapped[str | None] = mapped_column(String(20), default=None, comment='负责人')
|
||
phone: Mapped[str | None] = mapped_column(String(11), default=None, comment='手机')
|
||
email: Mapped[str | None] = mapped_column(String(50), default=None, comment='邮箱')
|
||
status: Mapped[int] = mapped_column(default=1, comment='部门状态(0停用 1正常)')
|
||
del_flag: Mapped[bool] = mapped_column(default=False, comment='删除标志(0删除 1存在)')
|
||
# 父级部门一对多
|
||
parent_id: Mapped[int | None] = mapped_column(
|
||
ForeignKey('sys_dept.id', ondelete='SET NULL'), default=None, index=True, comment='父部门ID'
|
||
)
|
||
parent: Mapped[Union['Dept', None]] = relationship(init=False, back_populates='children', remote_side=[id])
|
||
children: Mapped[list['Dept'] | None] = relationship(init=False, back_populates='parent')
|
||
# 部门用户一对多
|
||
users: Mapped[list['User']] = relationship(init=False, back_populates='dept') # noqa: F821
|