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

📄 databaseview.cpp

📁 Visual_C++.NET实用编程百例
💻 CPP
字号:
// databaseView.cpp : CdatabaseView 类的实现
//

#include "stdafx.h"
#include "database.h"

#include "databaseSet.h"
#include "databaseDoc.h"
#include "databaseView.h"
#include ".\databaseview.h"
#include "FildDlg.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// CdatabaseView

IMPLEMENT_DYNCREATE(CdatabaseView, CRecordView)

BEGIN_MESSAGE_MAP(CdatabaseView, CRecordView)
	// 标准打印命令
	ON_COMMAND(ID_FILE_PRINT, CRecordView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, CRecordView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, CRecordView::OnFilePrintPreview)
	ON_COMMAND(ID_MENUADD, OnMenuadd)
	ON_COMMAND(ID_MENUMODIFY, OnMenumodify)
	ON_COMMAND(ID_MENUDEL, OnMenudel)
	ON_COMMAND(ID_MENUFIND, OnMenufind)
	ON_COMMAND(ID_MENUNO, OnMenuno)
	ON_COMMAND(ID_MENUNAME, OnMenuname)
	ON_COMMAND(ID_MENULITERARY, OnMenuliterary)
	ON_COMMAND(ID_MENUMATH, OnMenumath)
	ON_COMMAND(ID_MENUTOTAL, OnMenutotal)
END_MESSAGE_MAP()

// CdatabaseView 构造/析构

CdatabaseView::CdatabaseView()
	: CRecordView(CdatabaseView::IDD)
	, m_bAdd(FALSE)
{
	m_pSet = NULL;
	// TODO: 在此处添加构造代码

}

CdatabaseView::~CdatabaseView()
{
}

void CdatabaseView::DoDataExchange(CDataExchange* pDX)
{
	CRecordView::DoDataExchange(pDX);
	// 可以在此处插入 DDX_Field* 函数以将控件“连接”到数据库字段,例如
	// DDX_FieldText(pDX, IDC_MYEDITBOX, m_pSet->m_szColumn1, m_pSet)
	// DDX_FieldCheck(pDX, IDC_MYCHECKBOX, m_pSet->m_bColumn2, m_pSet);
	// 有关更多信息,请参阅 MSDN 和 ODBC 示例
	 DDX_FieldText(pDX, IDC_EDIT1, m_pSet->m_NO, m_pSet);
	 DDX_FieldText(pDX, IDC_EDIT2, m_pSet->m_Name, m_pSet);
	 DDX_FieldText(pDX, IDC_EDIT3, m_pSet->m_Literary, m_pSet);
	 DDX_FieldText(pDX, IDC_EDIT4, m_pSet->m_Math, m_pSet);
	 DDX_FieldText(pDX, IDC_EDIT5, m_pSet->m_Total, m_pSet);
}

BOOL CdatabaseView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: 在此处通过修改 CREATESTRUCT cs 来修改窗口类或
	// 样式

	return CRecordView::PreCreateWindow(cs);
}

void CdatabaseView::OnInitialUpdate()
{
	m_pSet = &GetDocument()->m_databaseSet;
	CRecordView::OnInitialUpdate();
}


// CdatabaseView 打印

BOOL CdatabaseView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// 默认准备
	return DoPreparePrinting(pInfo);
}

void CdatabaseView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: 打印前添加额外的初始化
}

void CdatabaseView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: 打印后添加清除过程
}


// CdatabaseView 诊断

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

void CdatabaseView::Dump(CDumpContext& dc) const
{
	CRecordView::Dump(dc);
}

CdatabaseDoc* CdatabaseView::GetDocument() const // 非调试版本是内联的
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CdatabaseDoc)));
	return (CdatabaseDoc*)m_pDocument;
}
#endif //_DEBUG


// CdatabaseView 数据库支持
CRecordset* CdatabaseView::OnGetRecordset()
{
	return m_pSet;
}



// CdatabaseView 消息处理程序

void CdatabaseView::OnMenuadd()
{
	// TODO: 在此添加命令处理程序代码
	if(!m_pSet->CanAppend ())
		return;
	m_pSet->MoveLast ();
	m_pSet->AddNew ();
	UpdateData(TRUE);
	if(!m_pSet->Update ())
		AfxMessageBox("添加记录失败!");
	m_pSet->MoveNext ();
	m_bAdd=TRUE;
	UpdateData(FALSE);
}

void CdatabaseView::OnMenumodify()
{
	// TODO: 在此添加命令处理程序代码
	if(!m_pSet->CanAppend ())
		return;
	m_pSet->Edit();
	UpdateData(TRUE);
	if(!m_pSet->Update())
		AfxMessageBox("修改记录失败!");
	UpdateData(FALSE);
}

void CdatabaseView::OnMenudel()
{
	// TODO: 在此添加命令处理程序代码
	if(MessageBox("确定要删除该项记录吗?","提示",MB_YESNO)!=IDYES)
		return;
	try
	{
		m_pSet->Delete ();
	}
	catch(CDBException* e)
	{
		MessageBox("删除记录错误:\n"+e->m_strError ,NULL,MB_ICONEXCLAMATION);
		m_pSet->MoveFirst ();
		e->Delete ();
		UpdateData(FALSE);
		return;
	}
	m_pSet->MoveNext();
	if(m_pSet->IsEOF())
		m_pSet->MoveLast();
	UpdateData(FALSE);
}

void CdatabaseView::OnMenufind()
{
	// TODO: 在此添加命令处理程序代码
	CFildDlg dlg;
	int result = dlg.DoModal();
	if(result==IDOK)
	{
		m_pSet->MoveFirst ();
		while(!m_pSet->IsEOF ())
		{
			if(m_pSet->m_Name == dlg.m_strName)
			{
				UpdateData(FALSE);
				return;
			}
			m_pSet->MoveNext ();
		}
		AfxMessageBox("没有你要查找的人");
		return ;
	}

}

void CdatabaseView::OnMenuno()
{
	// TODO: 在此添加命令处理程序代码
	m_pSet->m_strSort ="NO";
	m_pSet->Requery ();
	UpdateData(FALSE);
}

void CdatabaseView::OnMenuname()
{
	// TODO: 在此添加命令处理程序代码
	m_pSet->m_strSort ="Name";
	m_pSet->Requery ();
	UpdateData(FALSE);
}

void CdatabaseView::OnMenuliterary()
{
	// TODO: 在此添加命令处理程序代码
	m_pSet->m_strSort ="Literary";
	m_pSet->Requery ();
	UpdateData(FALSE);
}

void CdatabaseView::OnMenumath()
{
	// TODO: 在此添加命令处理程序代码
	m_pSet->m_strSort ="Math";
	m_pSet->Requery ();
	UpdateData(FALSE);
}

void CdatabaseView::OnMenutotal()
{
	// TODO: 在此添加命令处理程序代码
	m_pSet->m_strSort ="Total";
	m_pSet->Requery ();
	UpdateData(FALSE);
}

⌨️ 快捷键说明

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