-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathAmountDlg.cpp
104 lines (91 loc) · 2.75 KB
/
AmountDlg.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
// AmountDlg.cpp : implementation file
//
#include "stdafx.h"
#include "Bank.h"
#include "AmountDlg.h"
#include "ADOConn.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CAmountDlg dialog
extern CString g_CustomerID;
CAmountDlg::CAmountDlg(CWnd* pParent /*=NULL*/)
: CDialog(CAmountDlg::IDD, pParent)
{
//{{AFX_DATA_INIT(CAmountDlg)
m_Amount = 0.0;
//}}AFX_DATA_INIT
}
void CAmountDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CAmountDlg)
DDX_Text(pDX, IDC_AMOUNT, m_Amount);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CAmountDlg, CDialog)
//{{AFX_MSG_MAP(CAmountDlg)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CAmountDlg message handlers
BOOL CAmountDlg::OnInitDialog()
{
CDialog::OnInitDialog();
// TODO: Add extra initialization here
// UpdateData();
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
void CAmountDlg::OnOK()
{
// TODO: Add extra validation here
UpdateData();
if(m_Amount<=0)
{
AfxMessageBox("存款额小于等于0,无法存款");
return;
}
//获取系统时间
//修改account表中的余额,并添加depositor表中的存款记录
CADOConn m_ADOConn;
_RecordsetPtr m_pRecordset;
m_ADOConn.OnInitADOConn();
_bstr_t balanceSQL,depSQL,preBalance,custID;
//取出先前的余额
_variant_t theValue;
double balance;
CString strBalance;
preBalance="select * from account where account_number='"+g_CustomerID+"'";
m_pRecordset=m_ADOConn.GetRecordset(preBalance);
theValue=m_pRecordset->GetCollect("balance");
if(theValue.vt!=VT_NULL)
strBalance=(char *)_bstr_t(theValue);
balance=atof(strBalance);
balance+=m_Amount;//余额加上存款为新的余额
CString strA;
strA.Format("%f",balance);
balanceSQL="update account set balance='"+strA+"' where\
account_number='"+g_CustomerID+"'";
m_ADOConn.ExecuteSQL(balanceSQL);
//查询客户id
custID="select distinct customer_id from account,depositor,customer where account.account_number=\
depositor.account_number and customer.customer_id=depositor.customer_id";
m_pRecordset=m_ADOConn.GetRecordset(custID);
theValue=m_pRecordset->GetCollect("customer_id");
CString m_CustomerId;
if(theValue.vt!=VT_NULL)
m_CustomerId=(char *)_bstr_t(theValue);
//添加存款记录
strA.Format("%f",m_Amount);
depSQL="insert into depositor(account_number,customer_id,account_type,access_date,amount)\
values('"+g_CustomerID+"','"+m_CustomerId+"','save'\
,convert(varchar,getdate(),120),'"+strA+"')";//获取系统时间
m_ADOConn.ExecuteSQL(depSQL);
m_ADOConn.ExitConnect();
AfxMessageBox("存款成功!");
CDialog::OnOK();
}