📄 account.cpp
字号:
// Account.cpp: implementation of the Account class.
//
//////////////////////////////////////////////////////////////////////
#include "stdafx.h"
#include <stdlib.h>
#include "Testbank.h"
#include "Account.h"
#include "ADOConn.h"
#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
Account::Account()
{
UserId="";
UserName="";
UserPwd="";
UserMoney=0;
}
Account::~Account()
{
}
CString Account::GetUserId()
{
return UserId;
}
void Account::SetUserId(int vUserId)
{
UserId=vUserId;
}
CString Account::GetUserName()
{
return UserName;
}
void Account::SetUserName(CString cUserName)
{
UserName=cUserName;
}
CString Account::GetUserPwd()
{
return UserPwd;
}
void Account::SetUserPwd(CString cUserPwd)
{
UserPwd=cUserPwd;
}
long Account::GetUserMoney()
{
return UserMoney;
}
void Account::SetUserMoney(long lUserMoney)
{
UserMoney=lUserMoney;
}
////////////////////////////////////////////////////////////////////////
// 函数名:Saving(CString cUserId,long lusermoney) //////
// 参数: cUserId为存户的帐号,lusermoney为存款金额 ////
// 功能: Account的成员函数,实现用户存钱。 /////
//////////////////////////////////////////////////////////////////////
void Account::Saving(CString cUserId,long lusermoney)
{
ADOConn m_ADOConn;
m_ADOConn.OnInitDBConnect();
_bstr_t vSQL;
vSQL="select * from Account";
_RecordsetPtr m_pRecordset;
m_pRecordset=m_ADOConn.GetRecordSet(vSQL);
while(!m_pRecordset->adoEOF)
{
CString temp;
temp=(LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("userID");
if(strcmp(cUserId,temp)==0)
{
UserMoney=atol((LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("usermoney"));
UserMoney=UserMoney+lusermoney;
char money[20];
ltoa(UserMoney,money,10);
m_pRecordset->PutCollect("usermoney",(_variant_t)money);
m_pRecordset->Update();
break;
}
m_pRecordset->MoveNext();
}
m_ADOConn.ExitConnect();
}
////////////////////////////////////////////////////////////////////////
// 函数名:GetData(CString cUserId) //////
// 参数: cUserId为查询用户的帐号 ////
// 功能: Account的成员函数,当用户输入查询帐号时,调用数据库,////
// 用查询的数据信息初始化一个Account类成员变量,保存用 ////
// 户好查询的信息。 ///
// 返回值: 返回1表示数据库有用户信息,返回-1表示该用户不存在 ////
//////////////////////////////////////////////////////////////////////
BOOL Account::GetData(CString cUserId)
{
ADOConn m_ADOConn;
m_ADOConn.OnInitDBConnect();
_bstr_t vSQL;
vSQL="select * from Account";
_RecordsetPtr m_pRecordset;
m_pRecordset=m_ADOConn.GetRecordSet(vSQL);
while(!m_pRecordset->adoEOF)
{
CString temp;
temp=(LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("userID");
if(strcmp(cUserId,temp)==0)
{
UserId=cUserId;
UserName=(LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("username");
UserPwd=(LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("userpwd");
UserMoney=atol((LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("usermoney"));
return 1;//查找成功
break;
}
m_pRecordset->MoveNext();
}
return -1;//无此用户的信息
m_ADOConn.ExitConnect();
}
////////////////////////////////////////////////////////////////////////
// 函数名:Withdraw(CString cUserId,long lusermoney) //////
// 参数: cUserId为查询用户的帐号,lusermoney为取款金额 。 ////
// 功能: Account的成员函数,当用户输入帐号时,调用数据库, ////
// 对数据库操作。 ///
// 返回值: 返回2表示操作成功,返回1表示该用户不存在,返回-1 ////
// 表示存钱不能为负。 ////
//////////////////////////////////////////////////////////////////////
int Account::Withdraw(CString cUserId,long lusermoney)
{
if(lusermoney>0)
{
ADOConn m_ADOConn;
m_ADOConn.OnInitDBConnect();
_bstr_t vSQL;
vSQL="select * from Account";
_RecordsetPtr m_pRecordset;
m_pRecordset=m_ADOConn.GetRecordSet(vSQL);
while(!m_pRecordset->adoEOF)
{
CString temp;
temp=(LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("userID");
if(strcmp(cUserId,temp)==0)
{
UserMoney=atol((LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("usermoney"));
if(UserMoney>=lusermoney)
{
UserMoney=UserMoney-lusermoney;
char money[20];
ltoa(UserMoney,money,10);
m_pRecordset->PutCollect("usermoney",(_variant_t)money);
m_pRecordset->Update();
return 2;//操作成功
break;
}
else
return 1;//用户号不一致
break;
}
m_pRecordset->MoveNext();
}
m_ADOConn.ExitConnect();
}
else
{
return -1; //金额不能为负
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -