forked from boyuanH/Bank
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPaymentDlg.cpp
126 lines (112 loc) · 2.65 KB
/
PaymentDlg.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
// PaymentDlg.cpp : implementation file
//
#include "stdafx.h"
#include "Bank.h"
#include "PaymentDlg.h"
#include "ADOConn.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CPaymentDlg dialog
CPaymentDlg::CPaymentDlg(CWnd* pParent /*=NULL*/)
: CDialog(CPaymentDlg::IDD, pParent)
{
//{{AFX_DATA_INIT(CPaymentDlg)
m_LoanNumber = _T("");
m_Amount = 0.0;
//}}AFX_DATA_INIT
}
void CPaymentDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CPaymentDlg)
DDX_Text(pDX, IDC_PAYMENTNUMBER, m_LoanNumber);
DDX_Text(pDX, IDC_PAYMENTAMOUNT, m_Amount);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CPaymentDlg, CDialog)
//{{AFX_MSG_MAP(CPaymentDlg)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CPaymentDlg message handlers
void CPaymentDlg::OnOK()
{
// TODO: Add extra validation here
UpdateData();
if(!CheckLoan())
{
AfxMessageBox("该贷款号不存在");
return;
}
if(m_Amount<=0)
{
AfxMessageBox("还款额不正确");
return;
}
if(!InsertLoan())
{
CString str;
str.Format("还款金额过多!!");
AfxMessageBox(str);
}
else
{
CString str;
str.Format("成功为该客户还款%f",m_Amount);
AfxMessageBox(str);
CDialog::OnOK();
}
}
int CPaymentDlg::CheckLoan()
{
_bstr_t vSQL;
vSQL="select * from loan where loan_number='"+m_LoanNumber+"'";
CADOConn m_ADOConn;
_RecordsetPtr m_Recordset;
m_ADOConn.OnInitADOConn();
m_Recordset=m_ADOConn.GetRecordset(vSQL);
if(m_Recordset->adoEOF)//记录集空
{
m_ADOConn.ExitConnect();
return 0;
}
else
{
m_ADOConn.ExitConnect();
return 1;
}
}
int CPaymentDlg::InsertLoan()
{
_bstr_t paySQL,amountSQL,loanSQL;
CADOConn m_ADOConn;
_RecordsetPtr m_pRecordset;
m_ADOConn.OnInitADOConn();
amountSQL="select amount from loan where loan_number='"+m_LoanNumber+"'";
m_pRecordset=m_ADOConn.GetRecordset(amountSQL);
double amount;
CString astr;
_variant_t theValue;
theValue=m_pRecordset->GetCollect("amount");
if(theValue.vt!=VT_NULL)
astr=(char *)_bstr_t(theValue);
amount=atof(astr);
amount-=m_Amount;
if(amount<0)
return 0;
CString str;
str.Format("%f",m_Amount);
paySQL="insert into payment(payment_number,payment_date,payment_amount)\
values('"+m_LoanNumber+"',convert(varchar,getdate(),120),'"+str+"')";
m_ADOConn.ExecuteSQL(paySQL); //将账号信息插入payment表中
CString fstr;
fstr.Format("%f",amount);
loanSQL="Update loan set amount='"+fstr+"' where loan_number='"+m_LoanNumber+"'";
m_ADOConn.ExecuteSQL(loanSQL);//修改loan表中的amount
m_ADOConn.ExitConnect();
return 1;
}