178 lines
9.8 KiB
C#
178 lines
9.8 KiB
C#
using System;
|
|
using System.Data;
|
|
using System.Data.SqlClient;
|
|
using System.Collections;
|
|
using System.Collections.Generic;
|
|
using AIMSModel;
|
|
using AIMSObjectQuery;
|
|
using System.Text;
|
|
|
|
namespace AIMSDAL
|
|
{
|
|
internal partial class DMedicalItem
|
|
{
|
|
public static bool Exists(string No)
|
|
{
|
|
StringBuilder strSql=new StringBuilder();
|
|
strSql.Append("select count(1) from MedicalItem where No="+No+"");
|
|
return HelperDB.DbHelperSQL.Exists(strSql.ToString());
|
|
}
|
|
|
|
public static void Add(MedicalItem MedicalItemObj)
|
|
{
|
|
StringBuilder strSql=new StringBuilder();
|
|
strSql.Append("insert into [MedicalItem](");
|
|
strSql.Append("No,Name,HelpCode,MedicalItemAlias,MedicalItemAliasHelpCode,RetailPrice,DosageKindId,Stand,BarCode,MedicalDictNo,DrugKindId,PharmaCologyId,InsuranceKind,InsuranceKindNH,Antibiotics,IsSkintest,Dosage,DosageUnit,PackingUnit,SplitUnit,Quotiety,IsValid,Remark,OperatorNo,OperatorName,OperateDate");
|
|
strSql.Append(")");
|
|
strSql.Append(" values (");
|
|
strSql.Append("'"+MedicalItemObj.No+"',");
|
|
strSql.Append("'"+MedicalItemObj.Name+"',");
|
|
strSql.Append("'"+MedicalItemObj.HelpCode+"',");
|
|
strSql.Append("'"+MedicalItemObj.MedicalItemAlias+"',");
|
|
strSql.Append("'"+MedicalItemObj.MedicalItemAliasHelpCode+"',");
|
|
strSql.Append(""+MedicalItemObj.RetailPrice+",");
|
|
strSql.Append(""+MedicalItemObj.DosageKindId+",");
|
|
strSql.Append("'"+MedicalItemObj.Stand+"',");
|
|
strSql.Append("'"+MedicalItemObj.BarCode+"',");
|
|
strSql.Append("'"+MedicalItemObj.MedicalDictNo+"',");
|
|
strSql.Append(""+MedicalItemObj.DrugKindId+",");
|
|
strSql.Append(""+MedicalItemObj.PharmaCologyId+",");
|
|
strSql.Append("'"+MedicalItemObj.InsuranceKind+"',");
|
|
strSql.Append("'"+MedicalItemObj.InsuranceKindNH+"',");
|
|
strSql.Append("'"+MedicalItemObj.Antibiotics+"',");
|
|
strSql.Append(""+MedicalItemObj.IsSkintest+",");
|
|
strSql.Append(""+MedicalItemObj.Dosage+",");
|
|
strSql.Append("'"+MedicalItemObj.DosageUnit+"',");
|
|
strSql.Append("'"+MedicalItemObj.PackingUnit+"',");
|
|
strSql.Append("'"+MedicalItemObj.SplitUnit+"',");
|
|
strSql.Append(""+MedicalItemObj.Quotiety+",");
|
|
strSql.Append(""+MedicalItemObj.IsValid+",");
|
|
strSql.Append("'"+MedicalItemObj.Remark+"',");
|
|
strSql.Append("'"+MedicalItemObj.OperatorNo+"',");
|
|
strSql.Append("'"+MedicalItemObj.OperatorName+"',");
|
|
strSql.Append("'"+MedicalItemObj.OperateDate+"'");
|
|
strSql.Append(")");
|
|
|
|
HelperDB.DbHelperSQL.ExecNonQuery(strSql.ToString());
|
|
}
|
|
|
|
public static MedicalItem GetModel(int Id)
|
|
{
|
|
MedicalItem MedicalItemObj = new MedicalItem();
|
|
StringBuilder strSql=new StringBuilder();
|
|
strSql.Append("select ");
|
|
strSql.Append("Id,No,Name,HelpCode,MedicalItemAlias,MedicalItemAliasHelpCode,RetailPrice,DosageKindId,Stand,BarCode,MedicalDictNo,DrugKindId,PharmaCologyId,InsuranceKind,InsuranceKindNH,Antibiotics,IsSkintest,Dosage,DosageUnit,PackingUnit,SplitUnit,Quotiety,IsValid,Remark,OperatorNo,OperatorName,OperateDate ");
|
|
strSql.Append(" from MedicalItem ");
|
|
strSql.Append(" where Id="+Id+"" );
|
|
DataSet ds = HelperDB.DbHelperSQL.GetDataSet(strSql.ToString());
|
|
if(ds.Tables[0].Rows.Count>0)
|
|
{
|
|
if(ds.Tables[0].Rows[0]["Id"].ToString()!="")
|
|
{
|
|
MedicalItemObj.Id = int.Parse(ds.Tables[0].Rows[0]["Id"].ToString());
|
|
}
|
|
MedicalItemObj.No = ds.Tables[0].Rows[0]["No"].ToString();
|
|
MedicalItemObj.Name = ds.Tables[0].Rows[0]["Name"].ToString();
|
|
MedicalItemObj.HelpCode = ds.Tables[0].Rows[0]["HelpCode"].ToString();
|
|
MedicalItemObj.MedicalItemAlias = ds.Tables[0].Rows[0]["MedicalItemAlias"].ToString();
|
|
MedicalItemObj.MedicalItemAliasHelpCode = ds.Tables[0].Rows[0]["MedicalItemAliasHelpCode"].ToString();
|
|
if(ds.Tables[0].Rows[0]["RetailPrice"].ToString()!="")
|
|
{
|
|
MedicalItemObj.RetailPrice = decimal.Parse(ds.Tables[0].Rows[0]["RetailPrice"].ToString());
|
|
}
|
|
if(ds.Tables[0].Rows[0]["DosageKindId"].ToString()!="")
|
|
{
|
|
MedicalItemObj.DosageKindId = int.Parse(ds.Tables[0].Rows[0]["DosageKindId"].ToString());
|
|
}
|
|
MedicalItemObj.Stand = ds.Tables[0].Rows[0]["Stand"].ToString();
|
|
MedicalItemObj.BarCode = ds.Tables[0].Rows[0]["BarCode"].ToString();
|
|
MedicalItemObj.MedicalDictNo = ds.Tables[0].Rows[0]["MedicalDictNo"].ToString();
|
|
if(ds.Tables[0].Rows[0]["DrugKindId"].ToString()!="")
|
|
{
|
|
MedicalItemObj.DrugKindId = int.Parse(ds.Tables[0].Rows[0]["DrugKindId"].ToString());
|
|
}
|
|
if(ds.Tables[0].Rows[0]["PharmaCologyId"].ToString()!="")
|
|
{
|
|
MedicalItemObj.PharmaCologyId = int.Parse(ds.Tables[0].Rows[0]["PharmaCologyId"].ToString());
|
|
}
|
|
MedicalItemObj.InsuranceKind = ds.Tables[0].Rows[0]["InsuranceKind"].ToString();
|
|
MedicalItemObj.InsuranceKindNH = ds.Tables[0].Rows[0]["InsuranceKindNH"].ToString();
|
|
MedicalItemObj.Antibiotics = ds.Tables[0].Rows[0]["Antibiotics"].ToString();
|
|
if(ds.Tables[0].Rows[0]["IsSkintest"].ToString()!="")
|
|
{
|
|
MedicalItemObj.IsSkintest = int.Parse(ds.Tables[0].Rows[0]["IsSkintest"].ToString());
|
|
}
|
|
if(ds.Tables[0].Rows[0]["Dosage"].ToString()!="")
|
|
{
|
|
MedicalItemObj.Dosage = decimal.Parse(ds.Tables[0].Rows[0]["Dosage"].ToString());
|
|
}
|
|
MedicalItemObj.DosageUnit = ds.Tables[0].Rows[0]["DosageUnit"].ToString();
|
|
MedicalItemObj.PackingUnit = ds.Tables[0].Rows[0]["PackingUnit"].ToString();
|
|
MedicalItemObj.SplitUnit = ds.Tables[0].Rows[0]["SplitUnit"].ToString();
|
|
if(ds.Tables[0].Rows[0]["Quotiety"].ToString()!="")
|
|
{
|
|
MedicalItemObj.Quotiety = int.Parse(ds.Tables[0].Rows[0]["Quotiety"].ToString());
|
|
}
|
|
if(ds.Tables[0].Rows[0]["IsValid"].ToString()!="")
|
|
{
|
|
MedicalItemObj.IsValid = int.Parse(ds.Tables[0].Rows[0]["IsValid"].ToString());
|
|
}
|
|
MedicalItemObj.Remark = ds.Tables[0].Rows[0]["Remark"].ToString();
|
|
MedicalItemObj.OperatorNo = ds.Tables[0].Rows[0]["OperatorNo"].ToString();
|
|
MedicalItemObj.OperatorName = ds.Tables[0].Rows[0]["OperatorName"].ToString();
|
|
if(ds.Tables[0].Rows[0]["OperateDate"].ToString()!="")
|
|
{
|
|
MedicalItemObj.OperateDate = DateTime.Parse(ds.Tables[0].Rows[0]["OperateDate"].ToString());
|
|
}
|
|
}
|
|
return MedicalItemObj;
|
|
}
|
|
|
|
public static DataTable GetDataTable()
|
|
{
|
|
StringBuilder strSql = new StringBuilder();
|
|
strSql.Append("select [Id],[No],[Name],[HelpCode],[MedicalItemAlias],[MedicalItemAliasHelpCode],[RetailPrice],[DosageKindId],[Stand],[BarCode],[MedicalDictNo],[DrugKindId],[PharmaCologyId],[InsuranceKind],[InsuranceKindNH],[Antibiotics],[IsSkintest],[Dosage],[DosageUnit],[PackingUnit],[SplitUnit],[Quotiety],[IsValid],[Remark],[OperatorNo],[OperatorName],[OperateDate] ");
|
|
strSql.Append(" FROM MedicalItem ");
|
|
|
|
return HelperDB.DbHelperSQL.GetDataTable(strSql.ToString());
|
|
}
|
|
|
|
public static DataTable GetMedicalItemDrugDataTable(string HelpCode, int IsValid)
|
|
{
|
|
string strSql = "SELECT mi.Id, mi.No, mi.Name,mi.MedicalItemAlias,mi.Stand,dk.Name AS DosageKindName,mi.BarCode,mi.MedicalDictNo, " +
|
|
"dk2.Name AS DrugKindName,pc.Name AS PharmaCologyName,mi.InsuranceKind,mi.InsuranceKindNH, " +
|
|
"mi.Antibiotics,CASE mi.IsSkintest WHEN 0 THEN '非皮试' WHEN 1 THEN '皮试' end as IsSkintest, " +
|
|
"mi.Dosage,mi.DosageUnit,mi.PackingUnit,mi.SplitUnit,mi.Quotiety,mi.Remark," +
|
|
"CASE mi.IsValid WHEN 0 THEN '无效' WHEN 1 THEN '有效' end as IsValid FROM MedicalItem mi " +
|
|
"LEFT JOIN DosageKind dk ON dk.Id =mi.DosageKindId " +
|
|
"LEFT JOIN DrugKind dk2 ON dk2.Id =mi.DrugKindId " +
|
|
"LEFT JOIN PharmaCology pc ON pc.Id =mi.PharmaCologyId " +
|
|
"WHERE mi.IsValid ='" + IsValid + "' and ((mi.Name LIKE '%" + HelpCode + "%') OR (mi.HelpCode LIKE '%" + HelpCode + "%') OR (mi.MedicalItemAlias LIKE '%" + HelpCode + "%') OR (mi.MedicalItemAliasHelpCode LIKE '%" + HelpCode + "%')) ";
|
|
|
|
return HelperDB.DbHelperSQL.GetDataTable(strSql.ToString());
|
|
}
|
|
public static DataTable GetMedicalItemByDrugKindId(int DrugKindId)
|
|
{
|
|
string strSql = "SELECT mi.Id, mi.No, mi.Name,mi.MedicalItemAlias,mi.Stand,dk.Name AS DosageKindName,mi.BarCode,mi.MedicalDictNo, " +
|
|
"dk2.Name AS DrugKindName,pc.Name AS PharmaCologyName,mi.InsuranceKind,mi.InsuranceKindNH, " +
|
|
"mi.Antibiotics,CASE mi.IsSkintest WHEN 0 THEN '非皮试' WHEN 1 THEN '皮试' end as IsSkintest, " +
|
|
"mi.Dosage,mi.DosageUnit,mi.PackingUnit,mi.SplitUnit,mi.Quotiety,mi.Remark," +
|
|
"CASE mi.IsValid WHEN 0 THEN '无效' WHEN 1 THEN '有效' end as IsValid FROM MedicalItem mi " +
|
|
"LEFT JOIN DosageKind dk ON dk.Id =mi.DosageKindId " +
|
|
"LEFT JOIN DrugKind dk2 ON dk2.Id =mi.DrugKindId " +
|
|
"LEFT JOIN PharmaCology pc ON pc.Id =mi.PharmaCologyId " +
|
|
"WHERE mi.DrugKindId ='" + DrugKindId + "'";
|
|
|
|
return HelperDB.DbHelperSQL.GetDataTable(strSql.ToString());
|
|
}
|
|
|
|
|
|
public static int GetMedicalItemByDictNo(string MedicalDictNo)
|
|
{
|
|
string strSql = "SELECT COUNT(*) RowsCount FROM MedicalItem mi WHERE mi.MedicalDictNo='" + MedicalDictNo + "'";
|
|
DataTable dt = HelperDB.DbHelperSQL.GetDataTable(strSql);
|
|
return int.Parse(dt.Rows[0]["RowsCount"].ToString());
|
|
}
|
|
}
|
|
}
|