resource_provision_base.py 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711
  1. from sqlalchemy import ForeignKey,Column, String, Numeric, DateTime, Integer,Float,Boolean,BigInteger,Text
  2. # from sqlalchemy.orm import declarative_base
  3. from sqlalchemy.ext.declarative import declarative_base
  4. from datetime import datetime
  5. import uuid
  6. Base = declarative_base()
  7. class WaterResourceProject(Base):
  8. __tablename__ = 'water_resource_projects'
  9. id = Column(Integer, primary_key=True, autoincrement=True, comment='数据自增键')
  10. jsdwzjlx = Column(String(50), comment='建设单位证件类型')
  11. lxfs = Column(String(50), comment='联系方式')
  12. sjtgbmtyshxydm = Column(String(18), comment='数据提供部门统一社会信用代码')
  13. jdgljgbm = Column(String(50), comment='监督管理机关编码')
  14. cd_time = Column(DateTime, comment='插入时间')
  15. sjtgbmmc = Column(String(400), comment='数据提供部门名称')
  16. ggmj = Column(String(50), comment='灌溉面积')
  17. sjtgbmxzqhdm = Column(String(12), comment='数据提供部门行政区划代码')
  18. jsdwzjhm = Column(String(50), comment='建设单位证件号码')
  19. xzqhdm = Column(String(50), comment='水利设施和水利工程所在地行政区划代码')
  20. cd_operation = Column(String(10), comment='新增数据类型 I-INSERT, U_UPDATE, D-DELETE')
  21. zdmj = Column(String(50), comment='占地面积')
  22. d_bmmc = Column(String(500), comment='前置机归属数源部门名称源')
  23. etl_time = Column(DateTime, comment='ETL时间')
  24. jssj = Column(String(50), comment='建设时间')
  25. jsdwmc = Column(String(400), comment='建设单位名称')
  26. slsshslgcmc = Column(String(400), comment='水利设施和水利工程名称')
  27. cd_batch = Column(String(200), comment='数据批次号')
  28. slsshslgcdd = Column(String(400), comment='水利设施和水利工程地点')
  29. jdgljg = Column(String(400), comment='监督管理机关')
  30. jingdu = Column(String(50), comment='经度')
  31. weidu = Column(String(50), comment='维度')
  32. is_delete = Column(Integer, comment='删除标识')
  33. class Config:
  34. allow_population_by_field_name = True
  35. orm_mode = True
  36. def to_dict(self):
  37. return {
  38. "id": self.id,
  39. "jsdwzjlx": self.jsdwzjlx,
  40. "lxfs": self.lxfs,
  41. "sjtgbmtyshxydm": self.sjtgbmtyshxydm,
  42. "jdgljgbm": self.jdgljgbm,
  43. "cd_time": self.cd_time,
  44. "sjtgbmmc": self.sjtgbmmc,
  45. "ggmj": self.ggmj,
  46. "sjtgbmxzqhdm": self.sjtgbmxzqhdm,
  47. "jsdwzjhm": self.jsdwzjhm,
  48. "xzqhdm": self.xzqhdm,
  49. "cd_operation": self.cd_operation,
  50. "zdmj": self.zdmj,
  51. "d_bmmc": self.d_bmmc,
  52. "etl_time": self.etl_time,
  53. "jssj": self.jssj,
  54. "jsdwmc": self.jsdwmc,
  55. "slsshslgcmc": self.slsshslgcmc,
  56. "cd_batch": self.cd_batch,
  57. "slsshslgcdd": self.slsshslgcdd,
  58. "jdgljg": self.jdgljg,
  59. "jingdu": self.jingdu,
  60. "weidu": self.weidu,
  61. # "is_delete": self.is_delete
  62. }
  63. class ResourceImportFileStatus(Base):
  64. __tablename__ = 'resource_import_file_status'
  65. id = Column(Integer, primary_key=True, autoincrement=True, comment='ID')
  66. file_uuid = Column(String(255), nullable=False, comment='文件uuid名称')
  67. file_name = Column(String(255), nullable=False, comment='文件名称')
  68. error_num = Column(Integer, nullable=False,default=0, comment='错误数量')
  69. warning_num = Column(Integer, nullable=False,default=0,comment='警告数量')
  70. status = Column(String(50), nullable=False, comment='状态')
  71. create_time = Column(DateTime, default=datetime.now, comment='创建时间')
  72. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='更新时间')
  73. user_id = Column(String(255), nullable=False, comment='操作账号')
  74. remark = Column(Text, comment='备注')
  75. resource_type = Column(String(255), nullable=False, comment='物资类型')
  76. class Config:
  77. orm_mode = True
  78. class Unit(Base):
  79. __tablename__ = 'rescue_units'
  80. id = Column(Integer, autoincrement=True, primary_key=True)
  81. name = Column(String(255), nullable=False, comment='单位名称')
  82. category = Column(String(100), nullable=False, comment='类别')
  83. address = Column(String(255), nullable=False, comment='地址')
  84. equipment = Column(String(255), comment='装备')
  85. training = Column(String(255), comment='训练')
  86. responsible_person = Column(String(100), comment='队伍负责人')
  87. contact_number = Column(String(20), comment='值班电话')
  88. longitude = Column(Float, comment='经度')
  89. latitude = Column(Float, comment='纬度')
  90. is_delete = Column(Integer, comment='删除标识')
  91. position = Column(String(100), comment='负责人职务')
  92. team_size = Column(Integer, comment='队伍人数')
  93. supervisor_unit = Column(String(100), comment='主管单位')
  94. add_time = Column(DateTime, comment='插入时间')
  95. unit_prop = Column(String, comment='队伍属性')
  96. unit_level = Column(String, comment='队伍级别')
  97. unit_favor = Column(String, comment='队伍特长')
  98. supervisor_unit_phone = Column(String, comment='主管单位联系人电话')
  99. supervisor_unit_contact = Column(String, comment='主管单位联系人')
  100. responsible_person_phone = Column(String, comment='队伍负责人移动电话')
  101. area = Column(String, comment='所属行政区域')
  102. founding_time = Column(String, comment='成立时间')
  103. def to_dict(self):
  104. return {
  105. "id": self.id,
  106. "name": self.name,
  107. "category": self.category,
  108. "address": self.address,
  109. "equipment": self.equipment,
  110. "training": self.training,
  111. "responsible_person": self.responsible_person,
  112. "contact_number": self.contact_number,
  113. "longitude": self.longitude,
  114. "latitude": self.latitude,
  115. "position": self.position, # 新增字段:负责人职务
  116. "team_size": self.team_size, # 新增字段:队伍人数
  117. "supervisor_unit": self.supervisor_unit, # 新增字段:主管单位
  118. "add_time": self.add_time,
  119. "unit_prop": self.unit_prop,
  120. "unit_level": self.unit_level,
  121. "unit_favor": self.unit_favor,
  122. "supervisor_unit_phone": self.supervisor_unit_phone,
  123. "supervisor_unit_contact": self.supervisor_unit_contact,
  124. "responsible_person_phone": self.responsible_person_phone,
  125. "area": self.area,
  126. "founding_time": self.founding_time,
  127. # "is_delete": self.is_delete
  128. }
  129. class Config:
  130. allow_population_by_field_name = True
  131. orm_mode = True
  132. class RescuePersonnel(Base):
  133. __tablename__ = 'rescue_personnel'
  134. id = Column(Integer, primary_key=True, autoincrement=True)
  135. name = Column(String(255), nullable=False, comment='姓名')
  136. contact_number = Column(String(20), nullable=False, comment='联系电话')
  137. gender = Column(String(10), nullable=False, comment='性别')
  138. current_address = Column(String(255), nullable=False, comment='现在地址')
  139. position = Column(String(100), comment='职务')
  140. unit_id = Column(Integer, comment='所属救援人员单位ID')
  141. unit_name = Column(Integer, comment='所属救援人员单位')
  142. is_delete = Column(Integer, default=0, comment='删除标识')
  143. modified_time = Column(DateTime, default=datetime.utcnow, onupdate=datetime.utcnow, comment='修改时间')
  144. created_time = Column(DateTime, default=datetime.utcnow, comment='创建时间')
  145. def to_dict(self):
  146. return {
  147. "id": self.id,
  148. "name": self.name,
  149. "contact_number": self.contact_number,
  150. "gender": self.gender,
  151. "current_address": self.current_address,
  152. "position": self.position,
  153. "unit_id": self.unit_id,
  154. # "is_delete": self.is_delete,
  155. "unit_name": self.unit_name,
  156. "modified_time": self.modified_time.isoformat() if self.modified_time else None,
  157. "created_time": self.created_time.isoformat() if self.created_time else None
  158. }
  159. class RescueStation(Base):
  160. __tablename__ = 'rescue_stations'
  161. id = Column(Integer, primary_key=True, autoincrement=True, comment='数字自增ID')
  162. data_id = Column(String(255), primary_key=True, default=uuid.uuid4, comment='uuid主键')
  163. fwdx = Column(String(100), comment='服务对象姓名')
  164. zj = Column(String(20), comment='所属镇街')
  165. lng = Column(String(30), comment='救助站经度')
  166. cd_time = Column(DateTime, comment='更新时间')
  167. fwdmc = Column(String(50), comment='救助站名称')
  168. fwnr = Column(String(500), comment='服务内容')
  169. add_time = Column(DateTime, comment='新增时间')
  170. cd_operation = Column(String(1), comment='操作方式')
  171. fwdlx = Column(String(2), comment='救助站类型')
  172. lxdh = Column(String(30), comment='联系电话')
  173. kfsj = Column(String(100), comment='开放时间')
  174. lat = Column(String(30), comment='救助站纬度')
  175. fwdjj = Column(String(1000), comment='救助站简介')
  176. lxr = Column(String(30), comment='联系人')
  177. fid = Column(String(36), comment='主键')
  178. fwdzt = Column(String(1), comment='服务点状态')
  179. fwdaddr = Column(String(80), comment='服务点地址')
  180. ssqx = Column(String(80), comment='所属区县') #新增
  181. is_delete = Column(Boolean, default=False, comment='删除标识')
  182. def to_dict(self):
  183. return {
  184. "id": self.id,
  185. "data_id": self.data_id,
  186. "fwdx": self.fwdx,
  187. "zj": self.zj,
  188. "lng": self.lng,
  189. "cd_time": self.cd_time.isoformat() if self.cd_time else None,
  190. "fwdmc": self.fwdmc,
  191. "fwnr": self.fwnr,
  192. "add_time": self.add_time.isoformat() if self.add_time else None,
  193. "cd_operation": self.cd_operation,
  194. "fwdlx": self.fwdlx,
  195. "lxdh": self.lxdh,
  196. "kfsj": self.kfsj,
  197. "lat": self.lat,
  198. "fwdjj": self.fwdjj,
  199. "lxr": self.lxr,
  200. "fid": self.fid,
  201. "fwdzt": self.fwdzt,
  202. "fwdaddr": self.fwdaddr,
  203. "ssqx":self.ssqx
  204. # "is_delete": self.is_delete
  205. }
  206. class DefenseProject(Base):
  207. __tablename__ = 'defense_projects'
  208. data_id = Column(String(255), primary_key=True, default=uuid.uuid4, comment='uuid主键')
  209. id = Column(BigInteger, primary_key=True, autoincrement=True, comment='数字自增ID')
  210. gcmc = Column(String(200), comment='工程名称')
  211. jsdw = Column(String(100), comment='建设单位')
  212. whdw = Column(String(100), comment='维护单位')
  213. rfzyjlgcs = Column(String(100), comment='人防专业监理工程师')
  214. jsdd = Column(String(100), comment='建设地点')
  215. cd_operation = Column(String(1), comment='操作方式')
  216. yjdxsmj = Column(Numeric(12), comment='应建人防地下室面积(㎡)')
  217. sjdxsmj = Column(Numeric(12), comment='实建人防地下室面积(㎡)')
  218. cd_time = Column(DateTime, default=datetime.utcnow, comment='更新时间')
  219. add_time = Column(DateTime, default=datetime.utcnow, comment='新增时间')
  220. jldw = Column(String(100), comment='监理单位')
  221. jsdwdm = Column(String(100), comment='建设单位统一社会信用代码')
  222. kgsj = Column(DateTime, comment='开工时间')
  223. stdw = Column(String(100), comment='审图单位')
  224. cd_batch = Column(String(100), comment='批次号') #新增
  225. rfsjdwdm = Column(String(100), comment='人防设计单位单位统一社会信用代码')
  226. rfsjdw = Column(String(100), comment='人防设计单位单位')
  227. ybrs = Column(Numeric, comment='掩蔽人数')
  228. stdwdm = Column(String(100), comment='审图单位统一社会信用代码')
  229. whdwdm = Column(String(100), comment='维护单位统一社会信用代码')
  230. jldwdm = Column(String(100), comment='监理单位统一社会信用代码')
  231. rfzjlgcs = Column(String(100), comment='人防总监理工程师')
  232. gcid = Column(String(50), comment='主键')
  233. extend2 = Column(String(200), comment='扩展2')
  234. data_area = Column(String(12), comment='数据区域')
  235. extend1 = Column(String(200), comment='扩展1')
  236. jgsj = Column(DateTime, comment='竣工时间')
  237. rffhsbdw = Column(String(100), comment='人防防护设备单位')#新增
  238. rffhsbdwdm = Column(String(100), comment='人防防护设备单位统一社会信用代码')#新增
  239. jingdu = Column(Float, comment='经度')#新增
  240. weidu = Column(Float, comment='纬度')#新增
  241. is_delete = Column(Boolean, default=False, comment='删除标识')
  242. def to_dict(self):
  243. return {
  244. "id": self.id,
  245. "data_id": str(self.data_id), # 确保UUID转换为字符串
  246. "gcmc": self.gcmc,
  247. "jsdw": self.jsdw,
  248. "whdw": self.whdw,
  249. "rfzyjlgcs": self.rfzyjlgcs,
  250. "jsdd": self.jsdd,
  251. "cd_operation": self.cd_operation,
  252. "yjdxsmj": self.yjdxsmj,
  253. "sjdxsmj": self.sjdxsmj,
  254. "cd_time": self.cd_time.isoformat() if self.cd_time else None,
  255. "add_time": self.add_time.isoformat() if self.add_time else None,
  256. "jldw": self.jldw,
  257. "jsdwdm": self.jsdwdm,
  258. "kgsj": self.kgsj.isoformat() if self.kgsj else None,
  259. "stdw": self.stdw,
  260. "rfsjdwdm": self.rfsjdwdm,
  261. "rfsjdw": self.rfsjdw,
  262. "ybrs": self.ybrs,
  263. "stdwdm": self.stdwdm,
  264. "whdwdm": self.whdwdm,
  265. "jldwdm": self.jldwdm,
  266. "rfzjlgcs": self.rfzjlgcs,
  267. "gcid": self.gcid,
  268. "extend2": self.extend2,
  269. "data_area": self.data_area,
  270. "extend1": self.extend1,
  271. "jgsj": self.jgsj.isoformat() if self.jgsj else None,
  272. "cd_batch":self.cd_batch,
  273. "rffhsbdw":self.rffhsbdw,
  274. "rffhsbdwdm":self.rffhsbdwdm,
  275. "jingdu":self.jingdu,
  276. "weidu":self.weidu
  277. # "is_delete": self.is_delete,
  278. }
  279. class Shelter(Base):
  280. __tablename__ = 'shelters'
  281. data_id = Column(String(255), primary_key=True, default=uuid.uuid4, comment='uuid主键')
  282. id = Column(Integer, primary_key=True, autoincrement=True, comment='数字自增ID')
  283. admin_area = Column(String(100), comment='行政区域')
  284. full_name = Column(String(200), comment='应急避难场所全称')
  285. address = Column(String(255), comment='应急避难场所地址')
  286. incident_type = Column(String(100), comment='按突发事件类型分类')
  287. shelter_type = Column(String(100), comment='避难种类')
  288. total_area = Column(Numeric, comment='应急避难场所占地总面积(平方米)')
  289. indoor_area = Column(Numeric, comment='应急避难场所室内面积(平方米)')
  290. capacity = Column(Numeric, comment='避难场所容纳人数(人)')
  291. supplies = Column(String(500), comment='物资储备')
  292. facilities = Column(String(500), comment='应急设施')
  293. is_delete = Column(Boolean, default=False, comment='删除标识')
  294. modified_time = Column(DateTime, default=datetime.utcnow, onupdate=datetime.utcnow, comment='修改时间')
  295. created_time = Column(DateTime, default=datetime.utcnow, comment='创建时间')
  296. def to_dict(self):
  297. return {
  298. "id": self.id,
  299. "data_id": str(self.data_id),
  300. "admin_area": self.admin_area,
  301. "full_name": self.full_name,
  302. "address": self.address,
  303. "incident_type": self.incident_type,
  304. "shelter_type": self.shelter_type,
  305. "total_area": self.total_area,
  306. "indoor_area": self.indoor_area,
  307. "capacity": self.capacity,
  308. "supplies": self.supplies,
  309. "facilities": self.facilities,
  310. # "is_delete": self.is_delete,
  311. "modified_time": self.modified_time.isoformat() if self.modified_time else None,
  312. "created_time": self.created_time.isoformat() if self.created_time else None,
  313. }
  314. class ResourceProvisionMaterialType(Base):
  315. __tablename__ = 'resource_provision_material_types'
  316. id = Column(Integer, autoincrement=True, primary_key=True, comment='物资类型ID')
  317. parent_id = Column(Integer, ForeignKey('resource_provision_material_types.id', ondelete='SET NULL'), comment='父类ID')
  318. material_category_name = Column(String(255), nullable=False, comment='物资类别名称')
  319. material_category_level = Column(Integer, comment='物资类别等级')
  320. sort_order = Column(Integer, comment='排序')
  321. display_status = Column(String(1), default='1', comment='显示状态(1显示 0不显示)')
  322. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  323. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  324. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  325. create_dept = Column(BigInteger, default=None, comment='创建部门')
  326. create_by = Column(BigInteger, default=None, comment='创建者')
  327. update_by = Column(BigInteger, default=None, comment='更新者')
  328. remark = Column(Text, nullable=True, comment='备注')
  329. def __repr__(self):
  330. return f"<MaterialType(name='{self.material_category_name}', level='{self.material_category_level}')>"
  331. class ResourceProvisionWarehouseInfo(Base):
  332. __tablename__ = 'resource_provision_warehouse_info'
  333. warehouse_id = Column(String(255), primary_key=True, autoincrement=True, comment='仓库id')
  334. warehouse_name = Column(String(255), nullable=True, comment='仓库名称')
  335. status = Column(String(50), nullable=True, comment='状态')
  336. contact_person = Column(String(100), nullable=True, comment='联系人')
  337. contact_phone = Column(String(20), nullable=True, comment='联系电话')
  338. address = Column(String(255), nullable=True, comment='地址')
  339. remark = Column(Text, nullable=True, comment='备注')
  340. type = Column(String(50), nullable=True, comment='类型')
  341. level = Column(String(50), nullable=True, comment='等级')
  342. storage_dept_id = Column(Integer, nullable=True, comment='物资保管部门id')
  343. storage_dept_name = Column(String(255), nullable=True, comment='物资保管部门名称')
  344. area_name = Column(String(100), nullable=True, comment='地区')
  345. longitude = Column(Numeric(9, 6), nullable=True, comment='经度')
  346. latitude = Column(Numeric(8, 6), nullable=True, comment='纬度')
  347. area = Column(Numeric(15, 2), nullable=True, comment='占地面积(平方米)')
  348. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  349. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  350. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  351. create_dept = Column(BigInteger, default=None, comment='创建部门')
  352. create_by = Column(BigInteger, default=None, comment='创建者')
  353. update_by = Column(BigInteger, default=None, comment='更新者')
  354. class ResourceProvisionWarehouseRoomInfo(Base):
  355. __tablename__ = 'resource_provision_warehouse_room_info'
  356. id = Column(String(255), primary_key=True, comment='ID')
  357. room_name = Column(String(255), nullable=True, comment='库房名称')
  358. warehouse = Column(String(255), nullable=True, comment='所在仓库')
  359. room_area = Column(Numeric(15, 2), nullable=True, comment='库房面积(平方米)')
  360. available_area = Column(Numeric(15, 2), nullable=True, comment='可用仓储面积(平方米)')
  361. height = Column(Numeric(10, 2), nullable=True, comment='高度(米)')
  362. room_volume = Column(Numeric(20, 2), nullable=True, comment='库房容积(立方米)')
  363. available_volume = Column(Numeric(20, 2), nullable=True, comment='可用库房容积(立方米)')
  364. level = Column(String(50), nullable=True, comment='等级')
  365. storage_type_code = Column(String(50), nullable=True, comment='存放类型')
  366. storage_type = Column(String(50), nullable=True, comment='保管类型')
  367. last_inventory_time = Column(DateTime, nullable=True, comment='库存确认最新时间')
  368. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  369. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  370. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  371. create_dept = Column(BigInteger, default=None, comment='创建部门')
  372. create_by = Column(BigInteger, default=None, comment='创建者')
  373. update_by = Column(BigInteger, default=None, comment='更新者')
  374. remark = Column(Text, nullable=True, comment='备注')
  375. class ResourceProvisionMaterialInfo(Base):
  376. __tablename__ = 'resource_provision_material_info'
  377. material_id = Column(Integer, primary_key=True, autoincrement=True, comment='物资编码')
  378. material_name = Column(String(255), nullable=True, comment='物资名称')
  379. warehouse_id = Column(Integer, nullable=True, comment='仓库id')
  380. inventory = Column(Integer, nullable=True, comment='库存')
  381. specification = Column(String(255), nullable=True, comment='规格')
  382. model = Column(String(255), nullable=True, comment='型号')
  383. category_name = Column(String(255), nullable=True, comment='分类名称')
  384. material_type = Column(String(255), nullable=True, comment='物资类型')
  385. unit_name = Column(String(255), nullable=True, comment='计量单位名称')
  386. brand_name = Column(String(255), nullable=True, comment='品牌名称')
  387. length = Column(Numeric(10, 2), nullable=True, comment='长(厘米)')
  388. width = Column(Numeric(10, 2), nullable=True, comment='宽(厘米)')
  389. height = Column(Numeric(10, 2), nullable=True, comment='高(厘米)')
  390. volume = Column(Numeric(20, 2), nullable=True, comment='体积(立方厘米)')
  391. gross_weight = Column(Numeric(10, 2), nullable=True, comment='毛重(kg)')
  392. net_weight = Column(Numeric(10, 2), nullable=True, comment='净重(kg)')
  393. manufacturer = Column(String(255), nullable=True, comment='生产厂商')
  394. origin = Column(String(255), nullable=True, comment='产地')
  395. status = Column(String(50), nullable=True, comment='状态')
  396. room_id = Column(Integer, nullable=True, comment='库房id')
  397. package_quantity = Column(Integer, nullable=True, comment='包装数量')
  398. package_volume = Column(Numeric(20, 2), nullable=True, comment='包装体积(立方厘米)')
  399. package_weight = Column(Numeric(10, 2), nullable=True, comment='包装重量(kg)')
  400. price = Column(Numeric(10, 2), nullable=True, comment='价格')
  401. selling_price = Column(Numeric(10, 2), nullable=True, comment='售卖价格')
  402. value = Column(Numeric(10, 2), nullable=True, comment='价值')
  403. cost_price = Column(Numeric(10, 2), nullable=True, comment='成本价格')
  404. disaster_types = Column(String(255), nullable=True, comment='适用灾种')
  405. maintenance = Column(Text, nullable=True, comment='使用保养')
  406. supplier_name = Column(String(255), nullable=True, comment='供应商名称')
  407. special_transportation_requirements = Column(Text, nullable=True, comment='特殊运输要求')
  408. material = Column(String(255), nullable=True, comment='材质')
  409. shelf_life = Column(DateTime, nullable=True, comment='保质期')
  410. inventory_warning_pusher = Column(String(255), nullable=True, comment='库存预警推送人')
  411. inventory_warning_quantity = Column(Integer, nullable=True, comment='库存预警数量')
  412. shelf_life_warning_days = Column(Integer, nullable=True, comment='保质期到期预警天数')
  413. shelf_life_warning_pusher = Column(String(255), nullable=True, comment='保质期预警推送人')
  414. from_sys= Column(String(255), nullable=True, comment='来源系统')
  415. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  416. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  417. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  418. create_dept = Column(BigInteger, default=None, comment='创建部门')
  419. create_by = Column(BigInteger, default=None, comment='创建者')
  420. update_by = Column(BigInteger, default=None, comment='更新者')
  421. remark = Column(Text, nullable=True, comment='备注')
  422. class ResourceProvisionFile(Base):
  423. __tablename__ = 'resource_provision_file'
  424. id = Column(Integer, autoincrement=True, primary_key=True)
  425. file_id = Column(String(50), nullable=False, comment='文件id')
  426. file_name = Column(String(255), nullable=False, comment='文件名称')
  427. file_name_desc = Column(String(255), nullable=False, comment='文件名称原名')
  428. file_path = Column(String(255), comment='文件存储路径')
  429. file_size = Column(String(50), comment='文件大小')
  430. status = Column(String(50), comment='文件状态')
  431. foreign_key = Column(String(50), comment='文件外键 --技术字段')
  432. from_scenario = Column(String(50), comment='对应标识 --技术字段')
  433. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  434. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  435. create_dept = Column(BigInteger, default=None, comment='创建部门')
  436. create_by = Column(BigInteger, default=None, comment='创建者')
  437. update_by = Column(BigInteger, default=None, comment='更新者')
  438. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)') #更新预案信息的时候 先将原有的进行备注删除
  439. remark = Column(Text, nullable=True, comment='备注')
  440. class Config:
  441. orm_mode = True
  442. class ResourceProvisionMaterialBarcode(Base):
  443. __tablename__ = 'resource_provision_material_barcode'
  444. id = Column(String(255), primary_key=True, comment='ID')
  445. material_code = Column(String(50), nullable=True, comment='物资编码')
  446. barcode = Column(String(255), nullable=True, comment='条形码')
  447. qr_code = Column(String(255), nullable=True, comment='二维码')
  448. status = Column(String(50), default='1',nullable=True, comment='状态')
  449. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  450. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  451. create_dept = Column(BigInteger, default=None, comment='创建部门')
  452. create_by = Column(BigInteger, default=None, comment='创建者')
  453. update_by = Column(BigInteger, default=None, comment='更新者')
  454. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  455. remark = Column(Text, nullable=True, comment='备注')
  456. class Config:
  457. orm_mode = True
  458. class ResourceProvisionProcurementDeclaration(Base):
  459. __tablename__ = 'resource_provision_procurement_declaration'
  460. id = Column(Integer, primary_key=True, comment='ID')
  461. declaration_date = Column(DateTime, default=datetime.now, nullable=False, comment='申报日期')
  462. declaration_amount = Column(Float, nullable=False, comment='申报金额(元)')
  463. declaration_unit = Column(String(255), nullable=False, comment='申报单位')
  464. declaration_person = Column(String(255), nullable=False, comment='申报人')
  465. declaration_details = Column(String(255), nullable=False, comment='申报情况')
  466. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  467. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  468. create_dept = Column(BigInteger, default=None, comment='创建部门')
  469. create_by = Column(BigInteger, default=None, comment='创建者')
  470. update_by = Column(BigInteger, default=None, comment='更新者')
  471. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  472. remark = Column(Text, nullable=True, comment='备注')
  473. class ResourceProvisionProcurementDeclarationDetail(Base):
  474. __tablename__ = 'resource_provision_procurement_declaration_detail'
  475. id = Column(Integer, primary_key=True, comment='ID')
  476. serial_number = Column(Integer, nullable=False, comment='序号')
  477. declaration_id = Column(String(255), nullable=False, comment='申报基础表id')
  478. warehouse_id= Column(String(255), nullable=False, comment='仓库id')
  479. material_type = Column(String(255), nullable=False, comment='物资类型')
  480. material_code = Column(String(255), nullable=False, comment='物资名称')
  481. material_quantity = Column(Integer, nullable=False, comment='物资数量(件)')
  482. material_unit_price = Column(Float, nullable=False, comment='物资单价')
  483. material_purpose = Column(Text, nullable=False, comment='物资用途')
  484. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  485. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  486. create_dept = Column(BigInteger, default=None, comment='创建部门')
  487. create_by = Column(BigInteger, default=None, comment='创建者')
  488. update_by = Column(BigInteger, default=None, comment='更新者')
  489. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  490. remark = Column(Text, nullable=True, comment='备注')
  491. class ResourceProvisionProcurementReview(Base):
  492. __tablename__ = 'resource_provision_procurement_review'
  493. id = Column(Integer, primary_key=True, comment='ID')
  494. reviewer = Column(String(255), nullable=False, comment='审核人')
  495. declaration_id = Column(Integer, nullable=False, comment='申报基础表id')
  496. review_result = Column(String(50), nullable=False, comment='审核结果')
  497. review_comments = Column(Text, comment='审核意见')
  498. review_date = Column(DateTime, default=datetime.now, comment='审核时间')
  499. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  500. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  501. create_dept = Column(BigInteger, default=None, comment='创建部门')
  502. create_by = Column(BigInteger, default=None, comment='创建者')
  503. update_by = Column(BigInteger, default=None, comment='更新者')
  504. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  505. remark = Column(Text, nullable=True, comment='备注')
  506. class ResourceProvisionDispatch(Base):
  507. __tablename__ = 'resource_provision_dispatch'
  508. id = Column(Integer, primary_key=True, comment='ID')
  509. dispatch_date = Column(DateTime, default=datetime.now, nullable=False, comment='调度日期')
  510. dispatch_purpose = Column(Text, nullable=False, comment='调度目的')
  511. dispatch_unit = Column(String(255), nullable=False, comment='申报单位')
  512. dispatch_person = Column(String(255), nullable=False, comment='申报人')
  513. dispatch_status = Column(String(255), nullable=False, comment='申报情况')
  514. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  515. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  516. create_dept = Column(BigInteger, default=None, comment='创建部门')
  517. create_by = Column(BigInteger, default=None, comment='创建者')
  518. update_by = Column(BigInteger, default=None, comment='更新者')
  519. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  520. remark = Column(Text, nullable=True, comment='备注')
  521. class ResourceProvisionDispatchDetail(Base):
  522. __tablename__ = 'resource_provision_dispatch_detail'
  523. id = Column(Integer, primary_key=True, comment='ID')
  524. serial_number = Column(Integer, nullable=False, comment='序号')
  525. dispatch_id = Column(String(255), nullable=False, comment='调度基础表id')
  526. warehouse_id= Column(String(255), nullable=False, comment='仓库id')
  527. material_type_id = Column(String(255), nullable=False, comment='物资类型id')
  528. material_type = Column(String(255), nullable=False, comment='物资类型')
  529. material_code = Column(String(255), nullable=False, comment='物资id')
  530. material_name = Column(String(255), nullable=False, comment='物资名称')
  531. material_quantity = Column(Integer, nullable=False, comment='物资数量(件)')
  532. material_purpose = Column(Text, nullable=False, comment='物资用途')
  533. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  534. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  535. create_dept = Column(BigInteger, default=None, comment='创建部门')
  536. create_by = Column(BigInteger, default=None, comment='创建者')
  537. update_by = Column(BigInteger, default=None, comment='更新者')
  538. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  539. remark = Column(Text, nullable=True, comment='备注')
  540. class ResourceProvisionDispatchReview(Base):
  541. __tablename__ = 'resource_provision_dispatch_review'
  542. id = Column(Integer, primary_key=True, comment='ID')
  543. reviewer = Column(String(255), nullable=False, comment='审核人')
  544. dispatch_id = Column(Integer, nullable=False, comment='调度基础表id')
  545. review_result = Column(String(50), nullable=False, comment='审核结果')
  546. review_comments = Column(Text, comment='审核意见')
  547. review_date = Column(DateTime, default=datetime.now, comment='审核时间')
  548. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  549. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  550. create_dept = Column(BigInteger, default=None, comment='创建部门')
  551. create_by = Column(BigInteger, default=None, comment='创建者')
  552. update_by = Column(BigInteger, default=None, comment='更新者')
  553. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  554. remark = Column(Text, nullable=True, comment='备注')
  555. class ResourceProvisionOutboundBasic(Base):
  556. __tablename__ = 'resource_provision_outbound_basic'
  557. id = Column(Integer, primary_key=True, autoincrement=True, comment='ID')
  558. outbound_number = Column(String(255), nullable=False, comment='出库单号')
  559. warehouse_id = Column(String(255), nullable=False, comment='仓库id')
  560. room_id = Column(String(255), comment='库房id')
  561. total_volume = Column(Numeric(20, 2), nullable=False, comment='出库单商品总体积(立方厘米)')
  562. total_weight = Column(Numeric(20, 2), nullable=False, comment='出库单商品总重量(kg)')
  563. total_shipping_volume = Column(Numeric(20, 2), nullable=False, comment='出库单发货总体积(立方厘米)')
  564. total_shipping_weight = Column(Numeric(20, 2), nullable=False, comment='出库单发货总重量(kg)')
  565. total_quantity = Column(Integer, nullable=False, comment='出库单商品总数量')
  566. shipping_time = Column(DateTime, comment='出库单发货时间')
  567. disaster_type = Column(String(255), comment='灾种名称')
  568. dispatching_agency = Column(String(255), comment='调运机构名称')
  569. shipper_name = Column(String(255), comment='发货人姓名')
  570. shipper_mobile = Column(String(20), comment='发货人手机')
  571. shipper_address = Column(String(255), comment='发货人地址')
  572. shipper_remark = Column(Text, comment='发货方备注')
  573. receiver_name = Column(String(255), comment='收货人姓名')
  574. receiver_mobile = Column(String(20), comment='收货人手机')
  575. receiver_address = Column(String(255), comment='收货人地址')
  576. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  577. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  578. create_dept = Column(BigInteger, default=None, comment='创建部门')
  579. create_by = Column(BigInteger, default=None, comment='创建者')
  580. update_by = Column(BigInteger, default=None, comment='更新者')
  581. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  582. remark = Column(Text, comment='备注')
  583. class ResourceProvisionWarehouseMovement(Base):
  584. __tablename__ = 'resource_provision_warehouse_movement'
  585. id = Column(Integer, primary_key=True, autoincrement=True, comment='ID')
  586. material_id = Column(String(255), nullable=False, comment='物资id')
  587. warehouse_id = Column(String(255), nullable=False, comment='仓库id')
  588. room_id = Column(String(255), comment='库房id')
  589. io_number = Column(String(255), nullable=False, comment='出入库单号')
  590. io_flag = Column(String(10), nullable=False, comment='出入库标识')
  591. changed_stock = Column(Integer, nullable=False, comment='变动库存')
  592. remaining_stock = Column(Integer, nullable=False, comment='剩余库存')
  593. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  594. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  595. create_dept = Column(BigInteger, default=None, comment='创建部门')
  596. create_by = Column(BigInteger, default=None, comment='创建者')
  597. update_by = Column(BigInteger, default=None, comment='更新者')
  598. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
  599. remark = Column(Text, comment='备注')
  600. class ResourceProvisionInboundBasic(Base):
  601. __tablename__ = 'resource_provision_inbound_basic'
  602. id = Column(Integer, primary_key=True, autoincrement=True, comment='ID')
  603. warehouse_id = Column(String(255), nullable=False, comment='仓库id')
  604. purchase_order_number = Column(String(255), nullable=False, comment='采购单号')
  605. is_donation = Column(String(10), nullable=False, comment='是否捐赠(是、否)')
  606. transport_order_number = Column(String(255), nullable=False, comment='运输单号')
  607. donator_phone = Column(String(20), comment='捐赠人联系电话')
  608. donator_name = Column(String(255), comment='捐赠人姓名')
  609. reviewer = Column(String(255), comment='审核人')
  610. enterprise_name = Column(String(255), comment='企业名称')
  611. enterprise_code = Column(String(255), comment='企业编号')
  612. grading_info = Column(String(255), comment='分级信息')
  613. type = Column(Integer, nullable=False, comment='类型(1 调拨入库、2 归还入库、3 回收入库)')
  614. supplier_name = Column(String(255), comment='供应商名称')
  615. creation_time = Column(DateTime,default=datetime.now, comment='创建时间')
  616. remark = Column(Text, comment='备注')
  617. supplier_code = Column(String(255), comment='供应商编号')
  618. completion_time = Column(DateTime, comment='完成时间')
  619. planned_completion_time = Column(DateTime, comment='计划完成时间')
  620. room_id = Column(String(255), comment='库房id')
  621. inbound_order_number = Column(String(255), comment='入库单号')
  622. new_time = Column(DateTime, default=datetime.now, comment='新增时间')
  623. create_time = Column(DateTime, default=datetime.now, comment='数据创建时间')
  624. update_time = Column(DateTime, default=datetime.now, onupdate=datetime.now, comment='数据更新时间')
  625. create_dept = Column(BigInteger, default=None, comment='创建部门')
  626. create_by = Column(BigInteger, default=None, comment='创建者')
  627. update_by = Column(BigInteger, default=None, comment='更新者')
  628. del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')