📄 adminview.cpp
字号:
// adminView.cpp : implementation file
//
#include "stdafx.h"
#include "biyesheji.h"
#include "adminView.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CadminView
IMPLEMENT_DYNCREATE(CadminView, CRecordView)
CadminView::CadminView()
: CRecordView(CadminView::IDD)
{
//{{AFX_DATA_INIT(CadminView)
m_pSet = NULL;
m_recno=0;
m_recnews = _T("");
m_reccount=0;
//}}AFX_DATA_INIT
}
CadminView::~CadminView()
{
((CBiyeshejiApp*)AfxGetApp())->m_userviews=0;//启用菜单 允许打开新窗口
if (m_pSet)
delete m_pSet;
}
void CadminView::DoDataExchange(CDataExchange* pDX)
{
CRecordView::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CadminView)
DDX_Control(pDX, IDC_XIA, m_movenext);
DDX_Control(pDX, IDC_SHANG, m_moveprev);
DDX_Control(pDX, IDC_QIAN, m_movefirst);
DDX_Control(pDX, IDC_HOU, m_movelast);
DDX_Control(pDX, IDC_LIST1, m_Grid);
DDX_Text(pDX, IDC_JILU, m_recnews);
DDX_FieldText(pDX, IDC_NAME, m_pSet->m_username, m_pSet);
DDX_FieldText(pDX, IDC_MIMA, m_pSet->m_mima, m_pSet);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CadminView, CRecordView)
//{{AFX_MSG_MAP(CadminView)
ON_BN_CLICKED(IDC_BUTTONCHA, OnButtoncha)
ON_BN_CLICKED(IDC_ADD, OnAdd)
ON_BN_CLICKED(IDC_HOU, OnHou)
ON_BN_CLICKED(IDC_QIAN, OnQian)
ON_BN_CLICKED(IDC_SHANCHU, OnShanchu)
ON_BN_CLICKED(IDC_SHANG, OnShang)
ON_BN_CLICKED(IDC_XIA, OnXia)
ON_BN_CLICKED(IDC_XIUGAI, OnXiugai)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CadminView diagnostics
#ifdef _DEBUG
void CadminView::AssertValid() const
{
CRecordView::AssertValid();
}
void CadminView::Dump(CDumpContext& dc) const
{
CRecordView::Dump(dc);
}
#endif //_DEBUG
/////////////////////////////////////////////////////////////////////////////
// CadminView message handlers
CRecordset* CadminView::OnGetRecordset()
{
if (m_pSet != NULL)
return m_pSet;
m_pSet = new CadminSet(NULL);
m_pSet->Open();
return m_pSet;
}
CadminSet* CadminView::GetRecordset()
{
CadminSet* pData = (CadminSet*) OnGetRecordset();
ASSERT(pData == NULL || pData->IsKindOf(RUNTIME_CLASS(CadminSet)));
return pData;
}
void CadminView::OnInitialUpdate()
{
BeginWaitCursor();
GetRecordset();
CRecordView::OnInitialUpdate();
CODBCFieldInfo DbFi;
LV_COLUMN m_Lc;
m_Lc.mask=LVCF_FMT|LVCF_WIDTH|LVCF_TEXT|LVCF_SUBITEM;
m_Grid.DeleteAllItems();
m_Grid.InsertColumn(0,"用户名",LVCFMT_CENTER,100);
m_Grid.InsertColumn(1,"密 码",LVCFMT_CENTER,60);
//GetDocument()->SetTitle("系统用户数据管理");//设置文档标题
//GetParent()->SetWindowText("系统用户数据管理");//设置子窗口标题
EndWaitCursor();
if (m_pSet->IsOpen())
if (!m_pSet->IsEOF())
{ //若记录集不为空,则遍历记录集,
//使GetRecordCount函数返回准确的记录数
while(!m_pSet->IsEOF())
m_pSet->MoveNext();
m_reccount=m_pSet->GetRecordCount();
m_pSet->MoveFirst();
m_recno=1;
//第一条记录是当前记录,禁止向前和第一条记录按钮
m_movefirst.EnableWindow(false);
m_moveprev.EnableWindow(false);
}
else
{
//如果没有记录,则禁止记录切换按钮
m_movefirst.EnableWindow(false);
m_moveprev.EnableWindow(false);
m_movenext.EnableWindow(false);
m_movelast.EnableWindow(false);
}
//显示当前记录号和记录总数
CString str;
str.Format("%d/%d",m_recno,m_reccount);
m_recnews=str; //设置记录信息成员变量
UpdateData(false); //将成员变量数据传递到窗口
}
void CadminView::OnButtoncha()
{
m_pSet->MoveFirst();
m_Grid.DeleteAllItems();
int i=0,j=0;
CString string;
LV_ITEM m_item;
m_item.mask=LVIF_TEXT;
while(m_pSet->IsEOF()==0)
{
m_item.iItem=i;
m_item.iSubItem=0;
m_pSet->GetFieldValue((short)0,string);
m_item.pszText=string.GetBuffer(string.GetLength());
m_Grid.InsertItem(&m_item);//插入条目
//显示列数据
for(j=1;j<m_pSet->m_nFields;j++)
{
m_pSet->GetFieldValue((short)j,string);
m_Grid.SetItemText(i,j,string.GetBuffer(string.GetLength()));
}
m_pSet->MoveNext();//下移记录
i++;
}
m_pSet->MoveFirst();
}
void CadminView::OnAdd()
{
// TODO: Add your control notification handler code here
try{
CString str;
m_pSet->AddNew();
UpdateData(true);//用窗体数据更新记录集
// CString str;
if (m_pSet->CanUpdate()) {
m_pSet->Update();//将记录集更新返回数据库
m_reccount++;
}
m_recno=m_reccount;
m_pSet->MoveLast();
str.Format("%d/%d",m_recno,m_reccount);
m_recnews=str; //设置记录信息成员变量
UpdateData(false); //刷新窗体
//启用向前和第一个记录按钮
m_movefirst.EnableWindow(true);
m_moveprev.EnableWindow(true);
//禁用向后和最后一个记录按钮
m_movenext.EnableWindow(false);
m_movelast.EnableWindow(false);
AfxMessageBox("成功添加记录!");
}
catch(CDBException* e) {
m_pSet->CancelUpdate();//撤销引起错误的操作
AfxMessageBox(e->m_strError);//显示错误信息
e->Delete();//删除错误对象
}
}
void CadminView::OnHou()
{
if(m_recno<m_reccount)
{
m_pSet->MoveLast();
m_recno=m_reccount;
//启用向前和第一个记录按钮
m_movefirst.EnableWindow(true);
m_moveprev.EnableWindow(true);
//禁用向后和最后一个记录按钮
m_movenext.EnableWindow(false);
m_movelast.EnableWindow(false);
//显示当前记录号和记录总数
CString str;
str.Format("%d/%d",m_recno,m_reccount);
m_recnews=str; //设置记录信息成员变量
UpdateData(false); //将成员变量数据传递到窗口
}
}
void CadminView::OnQian()
{
if(m_recno>1)
{
m_pSet->MoveFirst();
m_recno=1;
//禁用向前和第一个记录按钮
m_movefirst.EnableWindow(false);
m_moveprev.EnableWindow(false);
//启用向后和最后一个记录按钮
m_movenext.EnableWindow(true);
m_movelast.EnableWindow(true);
//显示当前记录号和记录总数
CString str;
str.Format("%d/%d",m_recno,m_reccount);
m_recnews=str; //设置记录信息成员变量
UpdateData(false); //将成员变量数据传递到窗口
}
}
void CadminView::OnShanchu()
{
if (m_recno>0)
{ //若有当前记录,则执行删除操作
try {
m_pSet->Delete();//删除当前记录
}
catch(CDBException* e) {
m_pSet->CancelUpdate();//撤销引起错误的操作
//如果删除操作发生错误,则显示错误信息
AfxMessageBox(e->m_strError);//显示错误信息
e->Delete();//删除错误对象
m_pSet->MoveFirst(); //使第一条记录成为当前记录
m_recno=1;
UpdateData(false);//刷新窗口
}
if (m_recno==m_reccount) {
//如果删除的是最后一条记录,则使前一条记录成为当前记录
m_pSet->MovePrev();
m_recno--;
}
else {
m_pSet->MoveNext();//使下一条记录成为当前记录
}
m_reccount--;
//显示当前记录号和记录总数
CString str;
str.Format("%d/%d",m_recno,m_reccount);
m_recnews=str; //设置记录信息成员变量
UpdateData(false); //将成员变量数据传递到窗口
if (m_recno<=1)
{ //若已经是第一个记录,则禁用向前和第一个记录按钮
m_movefirst.EnableWindow(false);
m_moveprev.EnableWindow(false);
}
else
{ //若不是第一个记录,则启用向前和第一个记录按钮
m_movefirst.EnableWindow(true);
m_moveprev.EnableWindow(true);
}
if (m_recno==m_reccount)
{ //若已经是最后一个记录,则禁用向后和最后一个记录按钮
m_movenext.EnableWindow(false);
m_movelast.EnableWindow(false);
}
else
{ //若不是最后一个记录,则启用向后和最后一个记录按钮
m_movenext.EnableWindow(true);
m_movelast.EnableWindow(true);
}
}
}
void CadminView::OnShang()
{
if (m_recno>1)
{
m_pSet->MovePrev();
m_recno--;
//显示当前记录号和记录总数
CString str;
str.Format("%d/%d",m_recno,m_reccount);
m_recnews=str; //设置记录信息成员变量
UpdateData(false); //将成员变量数据传递到窗口
}
//启用向后和最后一个记录按钮
m_movenext.EnableWindow(true);
m_movelast.EnableWindow(true);
if (m_recno==1)
{ //若已经是第一个记录,则禁用向前和第一个记录按钮
m_movefirst.EnableWindow(false);
m_moveprev.EnableWindow(false);
}
else
{ //若不是第一个记录,则启用向前和第一个记录按钮
m_movefirst.EnableWindow(true);
m_moveprev.EnableWindow(true);
}
}
void CadminView::OnXia()
{
if (m_recno<m_reccount)
{
m_pSet->MoveNext();
m_recno++;
//显示当前记录号和记录总数
CString str;
str.Format("%d/%d",m_recno,m_reccount);
m_recnews=str; //设置记录信息成员变量
UpdateData(false); //将成员变量数据传递到窗口
}
//启用向前和第一个记录按钮
m_movefirst.EnableWindow(true);
m_moveprev.EnableWindow(true);
if (m_recno==m_reccount)
{ //若已经是最后一个记录,则禁用向后和最后一个记录按钮
m_movenext.EnableWindow(false);
m_movelast.EnableWindow(false);
}
else
{ //若不是最后一个记录,则启用向后和最后一个记录按钮
m_movenext.EnableWindow(true);
m_movelast.EnableWindow(true);
}
}
void CadminView::OnXiugai()
{
if (m_recno>0)
{ //若有当前记录,则执行保存操作
/*UpdateData(true);//将窗体中显示的数据存入记录集
CString strval;
strval="m_xue";
m_pSet->m_strFilter="xue="'+strval+"'";
m_pSet->Requery();*/
m_pSet->Edit();//使当前记录进入编辑状态
UpdateData(true);//将窗体中显示的数据存入记录集
CString str;
if (m_pSet->CanUpdate())
{
m_pSet->Update();//将记录集的更新返回数据库
}
AfxMessageBox("成功保存数据!");
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -