ADT_A02_Handler.cs 4.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using Microsoft.Practices.EnterpriseLibrary.Data;
  6. using System.Transactions;
  7. using MediII.Adapter.ReceiveToScanModel;
  8. using IL.Common;
  9. using System.Data.Common;
  10. using System.Data;
  11. namespace MediII.Adapter.BizComponent.ADT
  12. {
  13. public class ADT_A02_Handler : ADTHandler
  14. {
  15. public override void Handler(string m)
  16. {
  17. #region 门诊就诊更新
  18. //初始化
  19. var rtnMsg = string.Empty;
  20. var msgHead = string.Empty;
  21. var msgBody = string.Empty;
  22. var resultCode = string.Empty;
  23. var result = string.Empty;
  24. WebService server = new WebService();
  25. OperateXmlUtil xmlHelper = new OperateXmlUtil();
  26. //读取配置的凭证号
  27. var cert = System.Configuration.ConfigurationManager.AppSettings["cert"];
  28. //读取就诊流水号
  29. string visitNo = xmlHelper.XpathRead(m, "//*[@root='2.16.156.10011.2.5.1.9']", "extension");
  30. var tmp = xmlHelper.XpathRead(m, "//*[name()='effectiveTime']");
  31. var visitDate = tmp[0].LastChild.Attributes["value"].Value;
  32. DateTime date = DateTime.ParseExact(visitDate, "yyyyMMddHHmmss", System.Globalization.CultureInfo.CurrentCulture);
  33. using (TransactionScope scope = new TransactionScope(TransactionScopeOption.RequiresNew))
  34. {
  35. #region 门诊就诊更新
  36. var isql = @"INSERT INTO HL7_Platform.dbo.HL7_Scan (ID ,ChartNo,VisitNo,OtherNo1,OtherNo2,OtherNo3,OtherName , TaskType , TaskStatus , UpdateUser , UpdateTime,Reserve1) VALUES (@ID ,@ChartNo ,@VisitNo ,@OtherNo1 , @OtherNo2 ,@OtherNo3 ,@OtherName ,@TaskType ,@TaskStatus , @UpdateUser , GETDATE(),@Reserve1)";
  37. //门诊处方单
  38. var dcmd = ctx.DBGetSqlStringCommand(isql);
  39. ctx.AddInParameter(dcmd, "id", System.Data.DbType.String, Guid.NewGuid().ToString("N"));
  40. ctx.AddInParameter(dcmd, "ChartNo", System.Data.DbType.String, visitNo);
  41. ctx.AddInParameter(dcmd, "VisitNo", System.Data.DbType.String, visitNo);
  42. ctx.AddInParameter(dcmd, "OtherNo1", System.Data.DbType.String, date.ToString("yyyy-MM-dd HH:mm:ss"));
  43. ctx.AddInParameter(dcmd, "OtherNo2", System.Data.DbType.String, "");
  44. ctx.AddInParameter(dcmd, "OtherNo3", System.Data.DbType.String, "");
  45. ctx.AddInParameter(dcmd, "OtherName", System.Data.DbType.String, "门诊处方单");
  46. ctx.AddInParameter(dcmd, "TaskType", System.Data.DbType.String, "ADT^A02[B01]");
  47. ctx.AddInParameter(dcmd, "TaskStatus", System.Data.DbType.Int32, 1);
  48. ctx.AddInParameter(dcmd, "UpdateUser", System.Data.DbType.String, "9999");
  49. ctx.AddInParameter(dcmd, "Reserve1", System.Data.DbType.String, "");
  50. ctx.DBExecuteNonQuery(dcmd);
  51. #endregion
  52. //门诊收费明细
  53. var lcmd = ctx.DBGetSqlStringCommand(isql);
  54. ctx.AddInParameter(lcmd, "id", System.Data.DbType.String, Guid.NewGuid().ToString("N"));
  55. ctx.AddInParameter(lcmd, "ChartNo", System.Data.DbType.String, visitNo);
  56. ctx.AddInParameter(lcmd, "VisitNo", System.Data.DbType.String, visitNo);
  57. ctx.AddInParameter(lcmd, "OtherNo1", System.Data.DbType.String, date.ToString("yyyy-MM-dd HH:mm:ss"));
  58. ctx.AddInParameter(lcmd, "OtherNo2", System.Data.DbType.String, "");
  59. ctx.AddInParameter(lcmd, "OtherNo3", System.Data.DbType.String, "");
  60. ctx.AddInParameter(lcmd, "OtherName", System.Data.DbType.String, "门诊收费明细");
  61. ctx.AddInParameter(lcmd, "TaskType", System.Data.DbType.String, "ADT^A02[B02]");
  62. ctx.AddInParameter(lcmd, "TaskStatus", System.Data.DbType.Int32, 1);
  63. ctx.AddInParameter(lcmd, "UpdateUser", System.Data.DbType.String, "9999");
  64. ctx.AddInParameter(lcmd, "Reserve1", System.Data.DbType.String, "");
  65. ctx.DBExecuteNonQuery(lcmd);
  66. scope.Complete();
  67. }
  68. #endregion
  69. }
  70. /// <summary>
  71. /// 获取急诊病人床位
  72. /// </summary>
  73. /// <param name="ctx"></param>
  74. /// <param name="visitNo"></param>
  75. /// <returns></returns>
  76. private string GetDepartNo(Database ctx, string roomBed)
  77. {
  78. var sql = string.Format("SELECT top 1 DepartNo FROM dbo.Depart WHERE DepartCode='{0}' AND DepartType='99' AND IsDel=0", roomBed);
  79. var dr = ctx.DBExecuteScalar(CommandType.Text, sql);
  80. return StrHelepr.Obj2StrTrim(dr);
  81. }
  82. }
  83. }