📄 databaseview.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 + -