sync.go 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319
  1. package controllers
  2. import (
  3. "Data_Upload_Api/enums"
  4. "Data_Upload_Api/models/sz"
  5. "Data_Upload_Api/service"
  6. "Data_Upload_Api/service/city"
  7. "Data_Upload_Api/utils"
  8. "fmt"
  9. _ "fmt"
  10. "github.com/astaxie/beego"
  11. _ "github.com/jinzhu/gorm"
  12. _ "math"
  13. _ "strconv"
  14. _ "strings"
  15. _ "time"
  16. )
  17. type SyncController struct {
  18. BaseAPIController
  19. }
  20. func SyncAPIRegisterRouters() {
  21. beego.Router("/sync/upload/hqyy", &SyncController{}, "get:SyncToHqyy")
  22. beego.Router("/sync/upload/lg2h", &SyncController{}, "get:SyncToLg2h")
  23. beego.Router("/sync/upload/smzy", &SyncController{}, "get:SyncToSmzy")
  24. }
  25. func (c *SyncController) SyncToLg2h() {
  26. // 第一步:到上报配置表中找到深圳需要上报的机构
  27. // sz_province, _ := beego.AppConfig.Int64("sz_province")
  28. // sz_city, _ := beego.AppConfig.Int64("sz_city")
  29. // configs, _ := service.FindAllDataUploadConfigOrgInfo(sz_province, sz_city, 3)
  30. org := &sz.DataUploadConfig{
  31. OrgId: 9598,
  32. ProvinceId: 19,
  33. CityId: 291,
  34. DepartmentName: "深圳市龙岗区第二人民医院",
  35. HospitalId: "455835506",
  36. InstType: 1,
  37. DbHost: "183.62.158.36",
  38. DbPort: "61433",
  39. DbPass: "LG2H+9897",
  40. DbUser: "sa",
  41. DbName: "xtzk",
  42. }
  43. // for _, org := range configs {
  44. // 第二步:跟进配置,创建数据库连接
  45. if len(org.DbHost) > 0 && len(org.DbUser) > 0 && len(org.DbPort) > 0 && len(org.DbPass) > 0 && len(org.DbName) > 0 {
  46. orgDb, err := service.CreateSqlServiceDB(org.DbHost, org.DbPort, org.DbUser, org.DbPass, org.DbName)
  47. if err != nil {
  48. utils.ErrorLog("创建数据库连接失败:%v", err)
  49. c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
  50. return
  51. }
  52. fmt.Println("触发了没有22222222")
  53. // 第三步:开始同步数据
  54. // 同步医院信息 t_hd_hospital
  55. // city.SyncHospital(orgDb, org.OrgId, org.HospitalId, org.InstType, org.DepartmentName)
  56. // // 同步水处理器 t_hd_wm
  57. // city.SyncWMS(orgDb, org.OrgId, org.HospitalId)
  58. // // // 同步员工 t_hd_staff
  59. // city.SyncStaff(orgDb, org.OrgId, org.HospitalId)
  60. // // // 同步病人 t_hd_patient
  61. // city.SyncPatient(orgDb, org.OrgId, org.HospitalId)
  62. // // // 同步排班 t_hd_shift
  63. // city.SyncShift(orgDb, org.OrgId, org.HospitalId)
  64. // // 同步处方 t_hd_ps
  65. // city.SyncPs(orgDb, org.OrgId, org.HospitalId)
  66. // // 同步处方药品 t_hd_ps
  67. // city.SyncPsMedicine(orgDb, org.OrgId, org.HospitalId)
  68. // // // 同步转院信息 t_hd_patient_out
  69. // city.SyncPatientOut(orgDb, org.OrgId, org.HospitalId)
  70. // // 同步处方信息 t_hd_doctors_advice
  71. // city.SyncDoctorAdvice(orgDb, org.OrgId, org.HospitalId)
  72. // // 同步透中信息 t_hd_middle
  73. // city.SyncMiddle(orgDb, org.OrgId, org.HospitalId)
  74. // // // 同步设备 t_hd_other_machine
  75. // city.SyncOtherMachine(orgDb, org.OrgId, org.HospitalId)
  76. // // // 同步维修 t_hd_maintain
  77. // city.SyncMachineRepair(orgDb, org.OrgId, org.HospitalId)
  78. // // // 同步设备 t_hd_dm
  79. // city.SyncDM(orgDb, org.OrgId, org.HospitalId)
  80. // // // 同步患者透析记录 t_hd_dialysis
  81. // city.SyncDialysis(orgDb, org.OrgId, org.HospitalId)
  82. // // 同步透析床位分区 t_hd_division
  83. // city.SyncDivision(orgDb, org.OrgId, org.HospitalId)
  84. // // 患者通路信息表(T_HD_ACCESS)
  85. // city.SyncAccess(orgDb, org.OrgId, org.HospitalId)
  86. // // 透析床位表(T_HD_SICKBED)
  87. // city.SyncSickbed(orgDb, org.OrgId, org.HospitalId)
  88. // // 患者诊断信息表(T_HD_DIAGNOSIS)
  89. // city.SyncDiagnosis(orgDb, org.OrgId, org.HospitalId)
  90. // 患者传染病检查记录表(T_HD_INFECTION
  91. //city.SyncInfection(orgDb, org.OrgId, org.HospitalId)
  92. // // 透析并发症记录表(T_HD_COMPLICATION)
  93. // city.SyncComplication(orgDb, org.OrgId, org.HospitalId)
  94. // // 血透患者检测结果表(T_HD_LIS_REPORT)
  95. // city.SyncLisReport(orgDb, org.OrgId, org.HospitalId)
  96. // // 血透患者检验结果指标表(T_HD_LIS_INDICATORS)
  97. // city.SyncLisIndicators(orgDb, org.OrgId, org.HospitalId)
  98. // 透析机透析液细菌培养检测记录表(t_hd_dm_dialysate_bc)
  99. // city.SyncLisCulture(orgDb,org.OrgId,org.HospitalId)
  100. //透析机透析液内毒素检测记录表(T_HD_DM_DIALYSATE_BC)
  101. // city.SyncDialysate(orgDb,org.OrgId,org.HospitalId)
  102. //物表消毒记录表(T_HD_SURFACE_DISINFECT)
  103. // city.SyncLisBodyDetection(orgDb,org.OrgId,org.HospitalId)
  104. // 第四步:关闭数据库连接
  105. //透析用水游离氯检测表(T_HD_WATER_FC)
  106. // city.SyncLisWaterFc(orgDb,org.OrgId,org.HospitalId)
  107. //透析用水有毒化学物检测表(T_HD_WATER_NC)
  108. // city.SynLisWaterNc(orgDb,org.OrgId,org.HospitalId)
  109. //透析用水PH值检测表(T_HD_WATER_PH)
  110. // city.SynLisWaterPh(orgDb,org.OrgId,org.HospitalId)
  111. //透析用水水硬度检测表(T_HD_WATER_WH)
  112. // city.SynListHadWater(orgDb,org.OrgId,org.HospitalId)
  113. //导管感染记录表(T_HD_CI)
  114. // city.SynListHdCi(orgDb,org.OrgId,org.HospitalId)
  115. //导管感染转归记录表(T_HD_CI_OUTCOME)
  116. // city.SynLisHdCiOutCome(orgDb,org.OrgId,org.HospitalId)
  117. //透析室空气消毒记录表(T_HD_AIR_DISINFECT)
  118. // city.SyncLisAirDetection(orgDb,org.OrgId,org.HospitalId)
  119. //透析用水细菌培养检测表(T_HD_WATER_BC)
  120. // city.SyncLisWaterBc(orgDb,org.OrgId,org.HospitalId)
  121. //透析用水内毒素检测表(T_HD_WATER_EN)
  122. // city.SyncLisWaterEn(orgDb,org.OrgId,org.HospitalId)
  123. // 第四步:关闭数据库连接
  124. service.CloseDB(orgDb)
  125. }
  126. // }
  127. c.ServeSuccessJSON(map[string]interface{}{
  128. "resultList": "12345",
  129. })
  130. return
  131. }
  132. func (c *SyncController) SyncToHqyy() {
  133. // 第一步:到上报配置表中找到深圳需要上报的机构
  134. // sz_province, _ := beego.AppConfig.Int64("sz_province")
  135. // sz_city, _ := beego.AppConfig.Int64("sz_city")
  136. // configs, _ := service.FindAllDataUploadConfigOrgInfo(sz_province, sz_city, 3)
  137. org := &sz.DataUploadConfig{
  138. OrgId: 9442,
  139. ProvinceId: 19,
  140. CityId: 291,
  141. DepartmentName: "暨南大学附属深圳华侨医院",
  142. HospitalId: "73307826X",
  143. InstType: 1,
  144. DbHost: "183.11.232.26",
  145. DbPort: "3306",
  146. DbPass: "1Q2W3e4r!@#$",
  147. DbUser: "sa",
  148. DbName: "xtzk",
  149. }
  150. // for _, org := range configs {
  151. // 第二步:跟进配置,创建数据库连接
  152. if len(org.DbHost) > 0 && len(org.DbUser) > 0 && len(org.DbPort) > 0 && len(org.DbPass) > 0 && len(org.DbName) > 0 {
  153. orgDb, err := service.CreateSqlServiceDB(org.DbHost, org.DbPort, org.DbUser, org.DbPass, org.DbName)
  154. if err != nil {
  155. utils.ErrorLog("创建数据库连接失败:%v", err)
  156. c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
  157. return
  158. }
  159. // 第三步:开始同步数据
  160. // 同步医院信息 t_hd_hospital
  161. city.SyncHospital(orgDb, org.OrgId, org.HospitalId, org.InstType, org.DepartmentName)
  162. // 同步水处理器 t_hd_wm
  163. city.SyncWMS(orgDb, org.OrgId, org.HospitalId)
  164. // // 同步员工 t_hd_staff
  165. city.SyncStaff(orgDb, org.OrgId, org.HospitalId)
  166. // // 同步病人 t_hd_patient
  167. city.SyncPatient(orgDb, org.OrgId, org.HospitalId)
  168. // // 同步排班 t_hd_shift
  169. city.SyncShift(orgDb, org.OrgId, org.HospitalId)
  170. // 同步处方 t_hd_ps
  171. city.SyncPs(orgDb, org.OrgId, org.HospitalId)
  172. // 同步处方药品 t_hd_ps
  173. city.SyncPsMedicine(orgDb, org.OrgId, org.HospitalId)
  174. // // 同步转院信息 t_hd_patient_out
  175. city.SyncPatientOut(orgDb, org.OrgId, org.HospitalId)
  176. // 同步处方信息 t_hd_doctors_advice
  177. city.SyncDoctorAdvice(orgDb, org.OrgId, org.HospitalId)
  178. // 同步透中信息 t_hd_middle
  179. city.SyncMiddle(orgDb, org.OrgId, org.HospitalId)
  180. // // 同步设备 t_hd_other_machine
  181. city.SyncOtherMachine(orgDb, org.OrgId, org.HospitalId)
  182. // // 同步维修 t_hd_maintain
  183. city.SyncMachineRepair(orgDb, org.OrgId, org.HospitalId)
  184. // // 同步设备 t_hd_dm
  185. city.SyncDM(orgDb, org.OrgId, org.HospitalId)
  186. // // 同步患者透析记录 t_hd_dialysis
  187. city.SyncDialysis(orgDb, org.OrgId, org.HospitalId)
  188. // 同步透析床位分区 t_hd_division
  189. city.SyncDivision(orgDb, org.OrgId, org.HospitalId)
  190. // 患者通路信息表(T_HD_ACCESS)
  191. city.SyncAccess(orgDb, org.OrgId, org.HospitalId)
  192. // 透析床位表(T_HD_SICKBED)
  193. city.SyncSickbed(orgDb, org.OrgId, org.HospitalId)
  194. // 患者诊断信息表(T_HD_DIAGNOSIS)
  195. city.SyncDiagnosis(orgDb, org.OrgId, org.HospitalId)
  196. // 患者传染病检查记录表(T_HD_INFECTION
  197. city.SyncInfection(orgDb, org.OrgId, org.HospitalId)
  198. // 透析并发症记录表(T_HD_COMPLICATION)
  199. city.SyncComplication(orgDb, org.OrgId, org.HospitalId)
  200. // 血透患者检测结果表(T_HD_LIS_REPORT)
  201. city.SyncLisReport(orgDb, org.OrgId, org.HospitalId)
  202. // 血透患者检验结果指标表(T_HD_LIS_INDICATORS)
  203. city.SyncLisIndicators(orgDb, org.OrgId, org.HospitalId)
  204. // 第四步:关闭数据库连接
  205. service.CloseDB(orgDb)
  206. }
  207. // }
  208. c.ServeSuccessJSON(map[string]interface{}{
  209. "resultList": "12345",
  210. })
  211. return
  212. }
  213. func (c *SyncController) SyncToSmzy() {
  214. // 第一步:到上报配置表中找到深圳需要上报的机构
  215. // sz_province, _ := beego.AppConfig.Int64("sz_province")
  216. // sz_city, _ := beego.AppConfig.Int64("sz_city")
  217. // configs, _ := service.FindAllDataUploadConfigOrgInfo(sz_province, sz_city, 3)
  218. org := &sz.DataUploadConfig{
  219. OrgId: 9504,
  220. ProvinceId: 19,
  221. CityId: 291,
  222. DepartmentName: "深圳生命之源血液透析中心",
  223. HospitalId: "MA5EU4PC0",
  224. InstType: 1,
  225. DbHost: "localhost",
  226. DbPort: "1433",
  227. DbPass: "1Q2W3e4r!@#$",
  228. DbUser: "sa",
  229. DbName: "xtzk",
  230. }
  231. // for _, org := range configs {
  232. // 第二步:跟进配置,创建数据库连接
  233. if len(org.DbHost) > 0 && len(org.DbUser) > 0 && len(org.DbPort) > 0 && len(org.DbPass) > 0 && len(org.DbName) > 0 {
  234. orgDb, err := service.CreateSqlServiceDB(org.DbHost, org.DbPort, org.DbUser, org.DbPass, org.DbName)
  235. if err != nil {
  236. utils.ErrorLog("创建数据库连接失败:%v", err)
  237. c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
  238. return
  239. }
  240. // 第三步:开始同步数据
  241. // 同步医院信息 t_hd_hospital
  242. city.SyncHospital(orgDb, org.OrgId, org.HospitalId, org.InstType, org.DepartmentName)
  243. // 同步水处理器 t_hd_wm
  244. city.SyncWMS(orgDb, org.OrgId, org.HospitalId)
  245. // // 同步员工 t_hd_staff
  246. city.SyncStaff(orgDb, org.OrgId, org.HospitalId)
  247. // // 同步病人 t_hd_patient
  248. city.SyncPatient(orgDb, org.OrgId, org.HospitalId)
  249. // // 同步排班 t_hd_shift
  250. city.SyncShift(orgDb, org.OrgId, org.HospitalId)
  251. // 同步处方 t_hd_ps
  252. city.SyncPs(orgDb, org.OrgId, org.HospitalId)
  253. // 同步处方药品 t_hd_ps
  254. city.SyncPsMedicine(orgDb, org.OrgId, org.HospitalId)
  255. // // 同步转院信息 t_hd_patient_out
  256. city.SyncPatientOut(orgDb, org.OrgId, org.HospitalId)
  257. // 同步处方信息 t_hd_doctors_advice
  258. city.SyncDoctorAdvice(orgDb, org.OrgId, org.HospitalId)
  259. // 同步透中信息 t_hd_middle
  260. city.SyncMiddle(orgDb, org.OrgId, org.HospitalId)
  261. // // 同步设备 t_hd_other_machine
  262. city.SyncOtherMachine(orgDb, org.OrgId, org.HospitalId)
  263. // // 同步维修 t_hd_maintain
  264. city.SyncMachineRepair(orgDb, org.OrgId, org.HospitalId)
  265. // // 同步设备 t_hd_dm
  266. city.SyncDM(orgDb, org.OrgId, org.HospitalId)
  267. // // 同步患者透析记录 t_hd_dialysis
  268. city.SyncDialysis(orgDb, org.OrgId, org.HospitalId)
  269. // 同步透析床位分区 t_hd_division
  270. city.SyncDivision(orgDb, org.OrgId, org.HospitalId)
  271. // 患者通路信息表(T_HD_ACCESS)
  272. city.SyncAccess(orgDb, org.OrgId, org.HospitalId)
  273. // 透析床位表(T_HD_SICKBED)
  274. city.SyncSickbed(orgDb, org.OrgId, org.HospitalId)
  275. // 患者诊断信息表(T_HD_DIAGNOSIS)
  276. city.SyncDiagnosis(orgDb, org.OrgId, org.HospitalId)
  277. // 患者传染病检查记录表(T_HD_INFECTION
  278. city.SyncInfection(orgDb, org.OrgId, org.HospitalId)
  279. // 透析并发症记录表(T_HD_COMPLICATION)
  280. city.SyncComplication(orgDb, org.OrgId, org.HospitalId)
  281. // 血透患者检测结果表(T_HD_LIS_REPORT)
  282. city.SyncLisReport(orgDb, org.OrgId, org.HospitalId)
  283. // 血透患者检验结果指标表(T_HD_LIS_INDICATORS)
  284. city.SyncLisIndicators(orgDb, org.OrgId, org.HospitalId)
  285. // 第四步:关闭数据库连接
  286. service.CloseDB(orgDb)
  287. }
  288. // }
  289. c.ServeSuccessJSON(map[string]interface{}{
  290. "resultList": "12345",
  291. })
  292. return
  293. }