ADT_A01_Handler.cs 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  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 System.Data;
  8. using IL.Common;
  9. namespace MediII.Adapter.BizComponent.ADT
  10. {
  11. public class ADT_A01_Handler : ADTHandler
  12. {
  13. public override void Handler(string m)
  14. {
  15. //初始化
  16. var rtnMsg = string.Empty;
  17. var msgHead = string.Empty;
  18. var msgBody = string.Empty;
  19. var resultCode = string.Empty;
  20. var result = string.Empty;
  21. WebService server = new WebService();
  22. OperateXmlUtil xmlHelper = new OperateXmlUtil();
  23. //读取配置的凭证号
  24. var cert = System.Configuration.ConfigurationManager.AppSettings["cert"];
  25. //读取就诊流水号
  26. string visitNo = xmlHelper.XpathRead(m, "//*[@root='2.16.156.10011.2.5.1.9']", "extension");
  27. var tmp=xmlHelper.XpathRead(m,"//*[name()='effectiveTime']");
  28. var visitDate=tmp[0].LastChild.Attributes["value"].Value;
  29. DateTime date = DateTime.ParseExact(visitDate, "yyyyMMddHHmmss", System.Globalization.CultureInfo.CurrentCulture);
  30. using (var scope = new TransactionScope(TransactionScopeOption.RequiresNew))
  31. {
  32. 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)";
  33. //门诊处方单
  34. var dcmd = ctx.DBGetSqlStringCommand(isql);
  35. ctx.DBAddInParameter(dcmd, "id", System.Data.DbType.String, Guid.NewGuid().ToString("N"));
  36. ctx.DBAddInParameter(dcmd, "ChartNo", System.Data.DbType.String, visitNo);
  37. ctx.DBAddInParameter(dcmd, "VisitNo", System.Data.DbType.String, visitNo);
  38. ctx.DBAddInParameter(dcmd, "OtherNo1", System.Data.DbType.String, date.ToString("yyyy-MM-dd HH:mm:ss"));
  39. ctx.DBAddInParameter(dcmd, "OtherNo2", System.Data.DbType.String, "");
  40. ctx.DBAddInParameter(dcmd, "OtherNo3", System.Data.DbType.String, "");
  41. ctx.DBAddInParameter(dcmd, "OtherName", System.Data.DbType.String, "门诊处方单");
  42. ctx.DBAddInParameter(dcmd, "TaskType", System.Data.DbType.String, "ADT^A01[B01]");
  43. ctx.DBAddInParameter(dcmd, "TaskStatus", System.Data.DbType.Int32, 1);
  44. ctx.DBAddInParameter(dcmd, "UpdateUser", System.Data.DbType.String, "9999");
  45. ctx.DBAddInParameter(dcmd, "Reserve1", System.Data.DbType.String, "");
  46. ctx.DBExecuteNonQuery(dcmd);
  47. //门诊收费明细
  48. var lcmd = ctx.DBGetSqlStringCommand(isql);
  49. ctx.AddInParameter(lcmd, "id", System.Data.DbType.String, Guid.NewGuid().ToString("N"));
  50. ctx.AddInParameter(lcmd, "ChartNo", System.Data.DbType.String, visitNo);
  51. ctx.AddInParameter(lcmd, "VisitNo", System.Data.DbType.String, visitNo);
  52. ctx.AddInParameter(lcmd, "OtherNo1", System.Data.DbType.String, date.ToString("yyyy-MM-dd HH:mm:ss"));
  53. ctx.AddInParameter(lcmd, "OtherNo2", System.Data.DbType.String, "");
  54. ctx.AddInParameter(lcmd, "OtherNo3", System.Data.DbType.String, "");
  55. ctx.AddInParameter(lcmd, "OtherName", System.Data.DbType.String, "门诊收费明细");
  56. ctx.AddInParameter(lcmd, "TaskType", System.Data.DbType.String, "ADT^A01[B02]");
  57. ctx.AddInParameter(lcmd, "TaskStatus", System.Data.DbType.Int32, 1);
  58. ctx.AddInParameter(lcmd, "UpdateUser", System.Data.DbType.String, "9999");
  59. ctx.AddInParameter(lcmd, "Reserve1", System.Data.DbType.String, "");
  60. ctx.DBExecuteNonQuery(lcmd);
  61. scope.Complete();
  62. }
  63. }
  64. public string GetDiagNo(string icdCode)
  65. {
  66. try
  67. {
  68. var sql = string.Format("SELECT DiagNo FROM HealthCare.dbo.Diag WHERE IcdCode='{0}'", icdCode);
  69. var obj = ctx.DBExecuteScalar(CommandType.Text, sql);
  70. var val = StrHelepr.Obj2StrTrim(obj);
  71. if (string.IsNullOrWhiteSpace(val))
  72. {
  73. val = icdCode;
  74. }
  75. return val;
  76. }
  77. catch (Exception ex)
  78. {
  79. IL.Common.LogHelper.LogError(string.Format("获取DiagNo错误:{0} {1}\r\n{2}", icdCode, ex.Message, ex.StackTrace), LogCatagories.MQAccess);
  80. return string.Empty;
  81. }
  82. }
  83. public string GetBedNo(Database ctx, string roombed)
  84. {
  85. var sql = "SELECT Top 1 BedNo FROM HealthCare.dbo.Bed WHERE RoomBed=@RoomBed";
  86. var cmd = ctx.DBGetSqlStringCommand(sql);
  87. ctx.AddInParameter(cmd, "RoomBed", DbType.String, roombed);
  88. var obj = StrHelepr.Obj2StrTrim(ctx.DBExecuteScalar(cmd));
  89. if (string.IsNullOrWhiteSpace(obj))
  90. {
  91. obj = roombed;
  92. }
  93. return obj;
  94. }
  95. }
  96. }