⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 price.cpp

📁 VC平台下开发的门诊信息管理系统 数据库ACCEES
💻 CPP
字号:
// Price.cpp : implementation file
//

#include "stdafx.h"
#include "Hospital.h"
#include "Price.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CPrice dialog


CPrice::CPrice(CWnd* pParent /*=NULL*/)
	: CDialog(CPrice::IDD, pParent)
{
	//{{AFX_DATA_INIT(CPrice)
	m_sCode = _T("");
	m_sICCard = _T("");
	m_sMedicament = _T("");
	m_sName = _T("");
	m_sPrice = _T("");
	m_nDiagnose = 0;
	//}}AFX_DATA_INIT
	m_sMedicamentID = "";
}


void CPrice::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CPrice)
	DDX_Text(pDX, IDC_CODE, m_sCode);
	DDX_Text(pDX, IDC_ICCARD, m_sICCard);
	DDX_Text(pDX, IDC_MEDICAMENT, m_sMedicament);
	DDX_Text(pDX, IDC_NAME, m_sName);
	DDX_Text(pDX, IDC_PRICE, m_sPrice);
	DDX_Text(pDX, IDC_DIAGNOSE, m_nDiagnose);
	DDV_MinMaxUInt(pDX, m_nDiagnose, 0, 10000);
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CPrice, CDialog)
	//{{AFX_MSG_MAP(CPrice)
	ON_EN_KILLFOCUS(IDC_NAME, OnKillfocusName)
	ON_EN_KILLFOCUS(IDC_CODE, OnKillfocusCode)
	ON_EN_KILLFOCUS(IDC_DIAGNOSE, OnKillfocusDiagnose)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CPrice message handlers

void CPrice::OnOK() 
{
	// 更新数据
	UpdateData(TRUE);

	// 打开就诊信息表
	try
	{
		// 构造SQL查询语句
		CString strSQL = "SELECT * FROM 划价记录";

		// 用构造的SQL语句打开记录集
		m_pRecordSet->Open(dbOpenDynaset, strSQL);

		// 滚动到最后一条记录
		if (m_pRecordSet->IsEOF() == FALSE)
			m_pRecordSet->MoveLast();

		// 准备添加新记录
		m_pRecordSet->AddNew();
	}
	catch (CDaoException* e)
	{
		AfxMessageBox(e->m_pErrorInfo->m_strDescription, MB_ICONEXCLAMATION);
		e->Delete();
		return;
	}

	// 得到并插入字段名
	CDaoFieldInfo m_fieldinfo;

	// 将对话框内容填写到数据库各字段
	for (int i = 1; i < m_pRecordSet->GetFieldCount(); i++)
	{    
		// 获取各字段信息
		m_pRecordSet->GetFieldInfo(i, m_fieldinfo);
		
		// 设置字段内容
		switch (i)
		{
		case 1:
			m_pRecordSet->SetFieldValue((LPCTSTR)m_fieldinfo.m_strName, (LPCTSTR)m_sPersonID);
			break;
		case 2:
			m_pRecordSet->SetFieldValue((LPCTSTR)m_fieldinfo.m_strName, (LPCTSTR)m_sMedicamentID);
			break;
		case 3:
			{
				CString sTemp;
				sTemp.Format("%d", m_nDiagnose);
				m_pRecordSet->SetFieldValue((LPCTSTR)m_fieldinfo.m_strName, (LPCTSTR)sTemp);
				break;
			}
		case 4:
			m_pRecordSet->SetFieldValue((LPCTSTR)m_fieldinfo.m_strName, (LPCTSTR)m_sPrice);
			break;
		}		
	}
	
	// 更新数据
	if (m_pRecordSet->CanUpdate() == TRUE)
		m_pRecordSet->Update();

	// 刷新
	if (m_pRecordSet->CanRestart() == TRUE)
		m_pRecordSet->Requery();
	
	// 关闭记录集
	if (m_pRecordSet->IsOpen())
		m_pRecordSet->Close();

	CDialog::OnOK();
}

void CPrice::OnKillfocusName() 
{
	// 更新数据
	UpdateData(TRUE);

	// 构造SQL查询语句
	CString strSQL = "SELECT * FROM 病人信息 WHERE 姓名 = '" + m_sName + "'";

	try
	{
		// 用构造的SQL语句打开记录集
		if (m_pRecordSet->IsOpen())
			m_pRecordSet->Close();
		m_pRecordSet->Open(dbOpenDynaset, strSQL);
		
		if (m_pRecordSet->GetRecordCount() > 0)
		{
			COleVariant varValue;
			m_pRecordSet->GetFieldValue(0, varValue);

			// 将得到的OLE变量转换为字符串变量
			const VARIANT* variant1 = LPCVARIANT(varValue);
			if (variant1->vt & VT_BYREF)
				return;
			m_sPersonID.Format("%d", variant1->lVal);

			m_pRecordSet->GetFieldValue(4, varValue);

			// 将得到的OLE变量转换为字符串变量
			const VARIANT* variant2 = LPCVARIANT(varValue);
			if (variant2->vt & VT_BYREF)
				return;
			m_sICCard.Format("%d", variant2->lVal);

			// 更新显示
			UpdateData(FALSE);
		}
		else
		{
			AfxMessageBox("病人姓名有误!");
		
			// 关闭记录集
			m_pRecordSet->Close();
			return;
		}

		// 关闭记录集
		m_pRecordSet->Close();
	}
	catch (CDaoException *e)
	{   
		AfxMessageBox(e->m_pErrorInfo->m_strDescription, MB_ICONEXCLAMATION);
		delete m_pRecordSet;
		e->Delete();
		return;
	}
}

void CPrice::OnKillfocusCode() 
{
	// 更新数据
	UpdateData(TRUE);

	// 构造SQL查询语句
	CString strSQL = "SELECT * FROM 药剂信息 WHERE 助记码 = '" + m_sCode + "'";

	try
	{
		// 用构造的SQL语句打开记录集
		if (m_pRecordSet->IsOpen())
			m_pRecordSet->Close();
		m_pRecordSet->Open(dbOpenDynaset, strSQL);
		
		if (m_pRecordSet->GetRecordCount() > 0)
		{
			COleVariant varValue;

			// 得到药品ID
			m_pRecordSet->GetFieldValue(0, varValue);
			const VARIANT* variant1 = LPCVARIANT(varValue);
			if (variant1->vt & VT_BYREF)
				return;
			m_sMedicamentID.Format("%d", variant1->lVal);

			// 得到药品名称
			m_pRecordSet->GetFieldValue(2, varValue);
			const VARIANT* variant2 = LPCVARIANT(varValue);
			if (variant2->vt & VT_BYREF)
				return;
			m_sMedicament = variant2->pcVal;

			// 得到单价
			m_pRecordSet->GetFieldValue(5, varValue);
			const VARIANT* variant3 = LPCVARIANT(varValue);
			m_varPrice.cyVal = variant3->cyVal;
			m_varPrice.vt = variant3->vt;
		
			// 更新显示
			UpdateData(FALSE);
		}
		else
		{
			AfxMessageBox("药剂名称有误!");
		
			// 关闭记录集
			m_pRecordSet->Close();
			return;
		}

		// 关闭记录集
		m_pRecordSet->Close();
	}
	catch (CDaoException *e)
	{   
		AfxMessageBox(e->m_pErrorInfo->m_strDescription, MB_ICONEXCLAMATION);
		delete m_pRecordSet;
		e->Delete();
		return;
	}
}

void CPrice::OnKillfocusDiagnose() 
{
	if (m_sMedicamentID == "")
		return;

	// 更新数据
	UpdateData(TRUE);

	// 计算总价
	COleCurrency price(m_varPrice);
	price *= m_nDiagnose;
	m_sPrice = price.Format();
	
	// 更新显示
	UpdateData(FALSE);
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -