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

📄 classview.cpp

📁 < Visual C++数据库经典开发实例精解>>的实例源码
💻 CPP
字号:
// ClassView.cpp : implementation file
//

#include "stdafx.h"
#include "TestApp.h"
#include "ClassView.h"

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

/////////////////////////////////////////////////////////////////////////////
// CClassView

IMPLEMENT_DYNCREATE(CClassView, CRecordView)

CClassView::CClassView()
	: CRecordView(CClassView::IDD)
{
	//{{AFX_DATA_INIT(CClassView)
	m_pSet = NULL;
	m_recnews = _T("");
	m_recno=0;//初始化当前记录号
	m_reccount=0;//初始化记录总数
	//}}AFX_DATA_INIT
}

CClassView::~CClassView()
{
	((CTestAppApp*)AfxGetApp())->m_ClassViews=0;//启用显示班级信息管理窗口菜单命令
	if (m_pSet)
		delete m_pSet;//删除访问Classes表的记录集指针
	if (m_pSetD)
		delete m_pSetD;//删除访问Deparment表的记录集指针
}

void CClassView::DoDataExchange(CDataExchange* pDX)
{
	CRecordView::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CClassView)
	DDX_Control(pDX, IDC_COMBO_DEPARTNAME, m_departmentname);
	DDX_Control(pDX, IDC_BUTTON_MOVEPREV, m_moveprev);
	DDX_Control(pDX, IDC_BUTTON_MOVENEXT, m_movenext);
	DDX_Control(pDX, IDC_BUTTON_MOVELAST, m_movelast);
	DDX_Control(pDX, IDC_BUTTON_MOVEFIRST, m_movefirst);
	DDX_Text(pDX, IDC_EDIT_RECNEWS, m_recnews);
	DDX_FieldText(pDX, IDC_EDIT_CLASSID, m_pSet->m_id, m_pSet);
	DDX_FieldText(pDX, IDC_EDIT_CLASSNAME, m_pSet->m_name, m_pSet);
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CClassView, CRecordView)
	//{{AFX_MSG_MAP(CClassView)
	ON_BN_CLICKED(IDC_SAVERECORD, OnSaverecord)
	ON_BN_CLICKED(IDC_BUTTON_MOVEPREV, OnButtonMoveprev)
	ON_BN_CLICKED(IDC_BUTTON_MOVENEXT, OnButtonMovenext)
	ON_BN_CLICKED(IDC_BUTTON_MOVELAST, OnButtonMovelast)
	ON_BN_CLICKED(IDC_BUTTON_MOVEFIRST, OnButtonMovefirst)
	ON_BN_CLICKED(IDC_ADDNEWRECORD, OnAddnewrecord)
	ON_BN_CLICKED(IDC_DELETERECORD, OnDeleterecord)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CClassView diagnostics

#ifdef _DEBUG
void CClassView::AssertValid() const
{
	CRecordView::AssertValid();
}

void CClassView::Dump(CDumpContext& dc) const
{
	CRecordView::Dump(dc);
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CClassView message handlers

CRecordset* CClassView::OnGetRecordset()
{
	if (m_pSet != NULL)
		return m_pSet;
	m_pSet = new CClassSet(NULL);
	m_pSet->Open();

	m_pSetD = new CDepartmentSet(NULL);//创建访问Deparment表的记录集指针
	m_pSetD->Open();//打开访问Deparment表的记录集

	return m_pSet;
}

CClassSet* CClassView::GetRecordset()
{
	CClassSet* pData = (CClassSet*) OnGetRecordset();
	ASSERT(pData == NULL || pData->IsKindOf(RUNTIME_CLASS(CClassSet)));
	return pData;
}

void CClassView::OnInitialUpdate()
{
	BeginWaitCursor();
	GetRecordset();
	CRecordView::OnInitialUpdate();
	GetDocument()->SetTitle("班级信息管理");//设置文档标题	
	GetParent()->SetWindowText("班级信息管理");//设置子窗口标题
	if (!m_pSet->IsOpen())
		m_pSet->Open();
	if (!m_pSet->IsEOF())
	{	//若记录集不为空,则遍历记录集,
		//使GetRecordCount函数返回准确的记录数
		while(!m_pSet->IsEOF())
				m_pSet->MoveNext();
		m_reccount=m_pSet->GetRecordCount();
		m_pSet->MoveFirst();
		m_recno=1;
	}
	//创建系部名称下拉列表
	if (!m_pSetD->IsOpen())
		m_pSetD->Open();	
	while(!m_pSetD->IsEOF())
	{		
		if(CB_ERR==m_departmentname.FindString(-1,m_pSetD->m_name))
			m_departmentname.AddString(m_pSetD->m_name);//不重复,加入列表
		m_pSetD->MoveNext();
	}
	ShowData();//显示当前记录
	EndWaitCursor();
}

void CClassView::OnSaverecord() 
{
	try{
	if (m_recno>0)
	{	//若有当前记录,则执行保存操作
		m_pSet->Edit();//使当前记录进入编辑状态
		UpdateData(true);//用窗体数据更新记录集id和name字段
		//根据系部名称确定系部编号
		CString str;
		m_departmentname.GetWindowText(str);
		m_pSetD->m_strFilter="name='" + str + "'";
		m_pSetD->Requery();
		m_pSet->m_departmentid=m_pSetD->m_id;//设置departmentid字段值
		if (m_pSet->CanUpdate())  {
			m_pSet->Update();//将记录集更新返回数据库
		}		
		AfxMessageBox("成功保存数据!");
	}	
	}
	catch(CDBException* e) {
		m_pSet->CancelUpdate();//撤销引起错误的操作		
		AfxMessageBox(e->m_strError);//显示错误信息
		e->Delete();//删除错误对象
	}
}

void CClassView::OnButtonMoveprev() 
{	//使前一个记录成为当前记录
	if (m_recno>1)
	{
		m_pSet->MovePrev();
		m_recno--;
		ShowData();//显示当前记录数据
	}
}

void CClassView::OnButtonMovenext() 
{	//使下一个记录成为当前记录
	if (m_recno<m_reccount)
	{
		m_pSet->MoveNext();
		m_recno++;
		ShowData();//显示当前记录数据
	}	
}

void CClassView::OnButtonMovelast() 
{	//使最后一个记录成为当前记录
	if(m_recno<m_reccount)
	{
		m_pSet->MoveLast();
		m_recno=m_reccount;
		ShowData();	//显示当前记录数据
	}		
}

void CClassView::OnButtonMovefirst() 
{	//使第一个记录成为当前记录
	if(m_recno>1)
	{
		m_pSet->MoveFirst();
		m_recno=1;
		ShowData();	//显示当前记录数据
	}	
}

void CClassView::OnAddnewrecord() 
{
	try{
		m_pSet->AddNew();
		UpdateData(true);//用窗体数据更新记录集id和name字段
		//根据系部名称确定系部编号
		CString str;
		m_departmentname.GetWindowText(str);
		m_pSetD->m_strFilter="name='" + str + "'";
		m_pSetD->Requery();
		m_pSet->m_departmentid=m_pSetD->m_id;//设置departmentid字段值
		if (m_pSet->CanUpdate())  {
			m_pSet->Update();//将记录集更新返回数据库
			m_reccount++;
		}
		m_recno=m_reccount;
		m_pSet->MoveLast();
		ShowData();
		AfxMessageBox("成功添加记录!");
	}
	catch(CDBException* e) {
		m_pSet->CancelUpdate();//撤销引起错误的操作		
		AfxMessageBox(e->m_strError);//显示错误信息
		e->Delete();//删除错误对象
	}	
}
void CClassView::ShowData() 
{
	if (m_pSet->IsOpen())
	{
		if (m_recno>1)
		{	//当前记录不是第一条记录,启用向前和第一条记录按钮
			m_movefirst.EnableWindow(true);
			m_moveprev.EnableWindow(true);
		}
		else
		{	//当前记录是第一条记录,则禁用向前和第一条记录按钮
			m_movefirst.EnableWindow(false);
			m_moveprev.EnableWindow(false);
		}
		if (m_recno==m_reccount)
		{	//当前记录是最后一条记录,禁用向后和最后一条记录按钮
			m_movenext.EnableWindow(false);
			m_movelast.EnableWindow(false);
		}
		else
		{	if(m_recno>=0)
			{	//若当前记录不是最后一条记录,则启用向后和最后一条记录按钮
				m_movenext.EnableWindow(true);
				m_movelast.EnableWindow(true);
			}
		}		
		//显示当前记录号和记录总数
		CString str;
		str.Format("%d/%d",m_recno,m_reccount);
		m_recnews=str;		//设置记录信息成员变量		
		//根据系部编号确定系部名称
		m_pSetD->m_strFilter="id='" + m_pSet->m_departmentid + "'";
		m_pSetD->Requery();
		m_departmentname.SelectString(-1,m_pSetD->m_name);
		UpdateData(false);	//将成员变量数据传递到窗口		
	}
}

void CClassView::OnDeleterecord() 
{
	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;
			ShowData();//刷新窗口
			return;
		}		
		if (m_recno==m_reccount) {		
			//如果删除的是最后一条记录,则使前一条记录成为当前记录
			m_pSet->MovePrev();
			m_recno--;
		}
		else {
			m_pSet->MoveNext();//使下一条记录成为当前记录			
		}
		m_reccount--;
		ShowData();//显示新的当前记录数据		
	}		
}

⌨️ 快捷键说明

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