taskRegistration_base.py 4.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. from sqlalchemy import Column, Integer, String, DateTime, ForeignKey,Text
  2. from sqlalchemy.ext.declarative import declarative_base
  3. from sqlalchemy.orm import relationship
  4. from datetime import datetime
  5. # from database import Base
  6. from sqlalchemy.ext.declarative import declarative_base
  7. from sqlalchemy.orm import relationship, sessionmaker
  8. from sqlalchemy import func
  9. # from sqlalchemy import Column, Integer, String, Text, DateTime, ForeignKey
  10. # from sqlalchemy.orm import relationship
  11. Base = declarative_base()
  12. class TaskRegistration(Base):
  13. __tablename__ = 'task_registrations'
  14. id = Column(Integer, primary_key=True, autoincrement=True, index=True,comment='id')
  15. task_id = Column(String(255), index=True,comment='任务ID')
  16. unit_name = Column(String(255), nullable=False,comment='部门名称')
  17. unit_id = Column(String(255), nullable=False,comment='部门ID')
  18. del_flag = Column(String(10),default='0', comment='是否删除')
  19. task_description = Column(Text, nullable=False,comment='任务内容/描述')
  20. registrar = Column(String(255), nullable=False,comment='登记人')
  21. registrar_id = Column(String(255), nullable=False,comment='登记人ID')
  22. creation_time = Column(DateTime, default=datetime.now,comment='创建时间')
  23. update_time = Column(DateTime, default=datetime.now,comment='更新时间')
  24. processing_status = Column(String(50), default='处理中',comment='任务状态')
  25. event_code = Column(String(50), nullable=False,comment='关联事件ID')
  26. task_type = Column(String(1), default='0', server_default='0', comment='任务类型 0 事件处置 1 防范措施 2 险情处理 3 督办任务')
  27. expire_time = Column(DateTime, comment='完成时限')
  28. feeback_user = Column(String(150), default='', server_default='', comment='反馈人员')
  29. # 你可以添加更多的字段和关系,例如与用户模型的外键关系
  30. # user_id = Column(Integer, ForeignKey('users.id'))
  31. # user = relationship("User", back_populates="task_registrations")
  32. class Config:
  33. orm_mode = True
  34. class TaskUnit(Base):
  35. __tablename__ = 'task_unit'
  36. id = Column(Integer, primary_key=True, autoincrement=True, index=True,comment='id')
  37. unit_name = Column(String(255), nullable=False, comment='部门名称')
  38. unit_duty = Column(Text, nullable=False,comment='部门职责')
  39. class Config:
  40. orm_mode = True
  41. class TaskFeeback(Base):
  42. __tablename__ = 'task_feeback'
  43. id = Column(Integer, primary_key=True, autoincrement=True, index=True,comment='id')
  44. task_id = Column(String(255), index=True,comment='任务ID')
  45. recorded_by = Column(Integer, nullable=False, comment='记录用户ID')
  46. feeback_user = Column(String(150), default='', server_default='', comment='反馈人员')
  47. content = Column(Text, comment='反馈内容')
  48. processing_status = Column(String(50), default='处理中',comment='任务状态')
  49. create_time = Column(DateTime, default=datetime.now, comment='登记时间')
  50. feeback_type = Column(String(1), default='0', server_default='0', comment='反馈类型 0 任务反馈 1 领导批示')
  51. leader_unit = Column(String(150), default='', server_default='', comment='领导单位')
  52. leader_name = Column(String(150), default='', server_default='', comment='领导姓名')
  53. approval_content = Column(Text, comment='批复内容')
  54. approval_time = Column(DateTime, comment='批复时间')
  55. class Config:
  56. orm_mode = True
  57. class TaskFile(Base):
  58. __tablename__ = 'task_file'
  59. id = Column(Integer, primary_key=True, autoincrement=True)
  60. file_id = Column(String(50), nullable=False, comment='文件id')
  61. file_name = Column(String(255), nullable=False, comment='文件名称')
  62. file_name_desc = Column(String(255), nullable=False, comment='文件名称原名')
  63. file_path = Column(String(255), nullable=True, comment='文件存储路径')
  64. file_size = Column(String(50), nullable=True, comment='文件大小')
  65. status = Column(String(50), nullable=True, comment='文件状态')
  66. foreign_key = Column(String(50), nullable=True, comment='文件外键 --技术字段')
  67. from_scenario = Column(String(50), nullable=True, comment='对应标识 --技术字段')
  68. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  69. create_dept = Column(Integer, default=None, comment='创建部门')
  70. create_by = Column(Integer, default=None, comment='创建者')
  71. create_time = Column(DateTime, default=datetime.now, comment='创建时间')
  72. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='更新时间')
  73. class Config:
  74. orm_mode = True