123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 |
- using Newtonsoft.Json.Linq;
- using System;
- using System.IO;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Data;
- using System.Drawing;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Windows.Forms;
- using PTMedicalInsurance.Common;
- using PTMedicalInsurance.Helper;
- using PTMedicalInsurance.FormSetter;
- using PTMedicalInsurance.Business;
- using PTMedicalInsurance.Variables;
- using System.Threading;
- //using FastReport.DevComponents.DotNetBar.Controls;
- namespace PTMedicalInsurance.Forms
- {
- public partial class MedInsuQuery : Form
- {
- DataTable dtExport;
- //1.声明自适应类实例
- AutoResizeForm asc = new AutoResizeForm();
- public MedInsuQuery()
- {
- InitializeComponent();
- asc.controllInitializeSize(this);
- asc.controlAutoSize(this);
- }
- private void btnClose_Click(object sender, EventArgs e)
- {
- Close();
- }
- private void MedInsuQuery_Load(object sender, EventArgs e)
- {
- dpST.Text = DateTime.Now.ToString("yyyy-MM-dd 00:00:00");
- dpED.Text = DateTime.Now.ToString("yyyy-MM-dd 23:59:59");
- // dgvSettlRecord.AutoGenerateColumns = false;
- GridViewSetter grdSetter = new GridViewSetter();
- grdSetter.SetHeaderTextOfMedInsuHosPerInfo(dgvSettlRecord);
- }
- private void btnQuery_Click(object sender, EventArgs e)
- {
- string errMsg;
- btnPrint.Enabled = false;
- string sCZYXM = Global.user.name;
- string SqlHeard = " Adm_Dr,MdtrtID,Name as PatientName,Age,PsnCertNO,Gend,PsnType,EmpName,AdmInDepName,insuplcAdmdvs,sZYZT AS sZTSM, "
- + " AdmBed,RegDate,MainDiagName,AttendDoctorNO,ChiefPhyDocName,'"+ sCZYXM+ "' as OpertName,'' as InHospNo,''Address ";
- string SqlStrMain = " SELECT a.*,b.*,a.PatientName AS Name,a.PsnType AS PsnTypeCode,'在院' sZYZT FROM BS_MIPatCurrentInsuInfo a LEFT JOIN BS_MedInsuRegisterInfo b "
- + " ON a.MdtrtID=b.InsuRegID AND a.Interface_Dr=b.Interface_Dr " //AND a.Hospital_Dr=b.Hospital_Dr
- + " WHERE b.Type=1 AND b.ValidFlag=1 AND b.Hospital_Dr= " + Global.inf.hospitalDr + " AND b.Interface_Dr= " + Global.inf.interfaceDr
- + " AND b.InsuRegID NOT IN (SELECT MdtrtID FROM BS_MedInsuSettlement WHERE MdtrtID=b.InsuRegID AND BillType=1 AND ValidFlag=1 AND AdmType=2) "
- + " AND b.RegDate<='" + dpED.Text + "' AND b.RegDate>'" + dpST.Text + "' " //
- + " UNION ALL "
- + " SELECT a.*,b.*,a.PatientName AS Name,a.PsnType AS PsnTypeCode,'已结算' AS sZYZT "
- + " FROM BS_MIPatCurrentInsuInfo a LEFT JOIN BS_MedInsuRegisterInfo b "
- + " ON a.MdtrtID=b.InsuRegID AND a.Interface_Dr=b.Interface_Dr " //AND a.Hospital_Dr=b.Hospital_Dr
- + " LEFT JOIN BS_MedInsuSettlement c ON b.InsuRegID=c.MdtrtID AND b.Interface_Dr=c.Interface_Dr " //AND a.MdtrtID=b.InsuRegID AND a.Interface_Dr=b.Interface_Dr
- + " WHERE b.Type=1 AND b.ValidFlag=1 AND c.BillType=1 AND b.Hospital_Dr= " + Global.inf.hospitalDr + " AND b.Interface_Dr= " + Global.inf.interfaceDr
- + " AND c.AdmType=2 AND c.SettlementDateTime<='" + dpED.Text + "' AND c.SettlementDateTime>'" + dpST.Text + "' "; //
- string sqlStr = " SELECT "+ SqlHeard + " FROM ("+ SqlStrMain +") M ";
- //MessageBox.Show(sqlStr);
- JObject joSqlstr = new JObject();
- joSqlstr.Add("sqlStr", sqlStr);
- joSqlstr.Add("Type", "MedInsuHosPInfo");
- joSqlstr.Add("hospID", Global.inf.hisHospitalDr);
- JArray jaParam = new JArray();
- jaParam.Add(joSqlstr);
- JObject joSettlQuery = new JObject();
- joSettlQuery.Add("params", jaParam);
- joSettlQuery.Add("code", "09010059");
- InvokeHelper invoker = new InvokeHelper();
- JObject joRtn = invoker.invokeInsuService(joSettlQuery.ToString(), "查询结算信息");
- //MessageBox.Show(joRtn.ToString());
- //if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
- //{
- // MessageBox.Show("查询失败:" + errMsg);
- // return;
- //}
- if (joRtn["result"]["data"].ToString() == "[]")
- {
- MessageBox.Show("查询结果为空!");
- return;
- }
- DataTable dt = (DataTable)joRtn["result"]["data"].ToObject(typeof(DataTable));
- dgvSettlRecord.DataSource = dt;
- if (dt.Rows.Count != 0)
- {
- btnPrint.Enabled = true;
- dtExport = dt;
- //从HIS获取患者的床号(分床前医保登记的病人床号没有写入医保平台登记表)
- for (int i = 0; i < dt.Rows.Count; i++)
- {
- string BedNo, BedDocName, InHospNo, Address;
- JObject joTmp = new JObject();
- joTmp.Add("admID", dt.Rows[i]["Adm_Dr"].ToString());
- JObject joRtn2 = invoker.invokeHISService(JsonHelper.setIrisInpar("05110014", joTmp).ToString(), "获取患者就诊信息");
- if (JsonHelper.parseIrisRtnValue(joRtn2, out errMsg) == 0)
- {
- BedNo = JsonHelper.getDestValue(JObject.Parse(joRtn2.ToString()), "mdtrtinfo.adm_bed");
- BedDocName = JsonHelper.getDestValue(JObject.Parse(joRtn2.ToString()), "mdtrtinfo.chfpdr_name");
- InHospNo = JsonHelper.getDestValue(JObject.Parse(joRtn2.ToString()), "mdtrtinfo.medrcdno");
- Address = JsonHelper.getDestValue(JObject.Parse(joRtn2.ToString()), "mdtrtinfo.Address");
- dt.Rows[i]["AdmBed"] = BedNo;
- dt.Rows[i]["AttendDoctorNO"] = BedDocName;
- dt.Rows[i]["InHospNo"] = InHospNo;
- dt.Rows[i]["Address"] = Address;
- }
- else
- {
- if (errMsg.IndexOf("请重新登录") > 0)
- {
- MessageBox.Show("获取患者信息失败,请重新登录系统!");
- break;
- }
- }
- }
- }
- }
- private void btnPrint_Click(object sender, EventArgs e)
- {
- string LSH = DateTime.Now.ToString("yyyy-MM-dd"); //DateTime.Now.ToString("MMddHHmmssffff");
- string sFliePathName = @"C:\Users\Administrator\Desktop\" + LSH + "医保在院患者登记或结算信息.xls";
- string ReturnFileName = ExportToExcel.DataTabletoExcel(dtExport, sFliePathName);
- if (ReturnFileName != "")
- {
- MessageBox.Show("导出成功,文件保存路径:【" + ReturnFileName + "】");
- System.Diagnostics.Process.Start(ReturnFileName); //打开excel文件
- }
- else
- {
- MessageBox.Show("导出失败!");
- }
- }
- }
- }
|