📄
字号:
// odbc2View.cpp : Codbc2View 类的实现
//
#include "stdafx.h"
#include "odbc2.h"
#include "odbc2Set.h"
#include "odbc2Doc.h"
#include "odbc2View.h"
#include ".\odbc2view.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
// Codbc2View
IMPLEMENT_DYNCREATE(Codbc2View, CRecordView)
BEGIN_MESSAGE_MAP(Codbc2View, 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_RECORD_ADD, OnRecordAdd)
ON_COMMAND(ID_SORT_ID, OnSortId)
ON_COMMAND(ID_SORT_NAME, OnSortName)
ON_COMMAND(ID_SORT_GRADE, OnSortGrade)
ON_COMMAND(ID_RECORD_DELETE, OnRecordDelete)
END_MESSAGE_MAP()
// Codbc2View 构造/析构
Codbc2View::Codbc2View()
: CRecordView(Codbc2View::IDD)
{
m_pSet = NULL;
m_bAdding = FALSE ;
// TODO: 在此处添加构造代码
}
Codbc2View::~Codbc2View()
{
}
void Codbc2View::DoDataExchange(CDataExchange* pDX)
{
CRecordView::DoDataExchange(pDX);
// 可以在此处插入 DDX_Field* 函数以将控件“连接”到数据库字段,例如
DDX_FieldText(pDX, IDC_STUDENTID, m_pSet->column1, m_pSet);
DDX_FieldText(pDX, IDC_STUDENTNAME, m_pSet->column2, m_pSet);
DDX_FieldText(pDX, IDC_STUDENTSEX, m_pSet->column3, m_pSet);
DDX_FieldText(pDX, IDC_STUDENTGRADE, m_pSet->column4, m_pSet);
// DDX_FieldCheck(pDX, IDC_MYCHECKBOX, m_pSet->m_bColumn2, m_pSet);
// 有关更多信息,请参阅 MSDN 和 ODBC 示例
}
BOOL Codbc2View::PreCreateWindow(CREATESTRUCT& cs)
{
// TODO: 在此处通过修改 CREATESTRUCT cs 来修改窗口类或
// 样式
return CRecordView::PreCreateWindow(cs);
}
void Codbc2View::OnInitialUpdate()
{
m_pSet = &GetDocument()->m_odbc2Set;
CRecordView::OnInitialUpdate();
}
// Codbc2View 打印
BOOL Codbc2View::OnPreparePrinting(CPrintInfo* pInfo)
{
// 默认准备
return DoPreparePrinting(pInfo);
}
void Codbc2View::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
// TODO: 打印前添加额外的初始化
}
void Codbc2View::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
// TODO: 打印后添加清除过程
}
// Codbc2View 诊断
#ifdef _DEBUG
void Codbc2View::AssertValid() const
{
CRecordView::AssertValid();
}
void Codbc2View::Dump(CDumpContext& dc) const
{
CRecordView::Dump(dc);
}
Codbc2Doc* Codbc2View::GetDocument() const // 非调试版本是内联的
{
ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(Codbc2Doc)));
return (Codbc2Doc*)m_pDocument;
}
#endif //_DEBUG
// Codbc2View 数据库支持
CRecordset* Codbc2View::OnGetRecordset()
{
return m_pSet;
}
// Codbc2View 消息处理程序
void Codbc2View::OnRecordAdd()
{
m_pSet->AddNew();
m_bAdding = TRUE ;
CEdit * pCtrl = (CEdit *) GetDlgItem(IDC_STUDENTID);
int result = pCtrl->SetReadOnly(FALSE);
UpdateData(FALSE);
// TODO: 在此添加命令处理程序代码
}
BOOL Codbc2View::OnMove(UINT nIDMoveCommand)
{
if(m_bAdding){
m_bAdding = FALSE ;
UpdateData(TRUE);
if(m_pSet->CanUpdate())
m_pSet->Update();
if(!m_pSet->IsEOF())
m_pSet->MoveLast();
m_pSet->Requery();
UpdateData(FALSE);
CEdit * pCtrl = (CEdit *) GetDlgItem(IDC_STUDENTID);
pCtrl->SetReadOnly(TRUE);
return TRUE ;
}
else{
switch(nIDMoveCommand)
{
case ID_RECORD_PREV:
m_pSet->MovePrev();
if(!m_pSet->IsBOF())
break ;
case ID_RECORD_FIRST:
m_pSet->MoveFirst();
break ;
case ID_RECORD_NEXT:
m_pSet->MoveNext();
if(!m_pSet->IsBOF())
break ;
if(!m_pSet->CanScroll()){
break ;
}
case ID_RECORD_LAST:
m_pSet->MoveLast();
break ;
default:
ASSERT(FALSE);
}
UpdateData(FALSE);
return TRUE ;
}
// TODO: 在此添加专用代码和/或调用基类
return CRecordView::OnMove(nIDMoveCommand);
}
void Codbc2View::OnSortId()
{
m_pSet->Close();
m_pSet->m_strSort = "学号";
m_pSet->Open();
UpdateData(FALSE);
// TODO: 在此添加命令处理程序代码
}
void Codbc2View::OnSortName()
{
m_pSet->Close();
m_pSet->m_strSort = "姓名";
m_pSet->Open();
UpdateData(FALSE);
// TODO: 在此添加命令处理程序代码
}
void Codbc2View::OnSortGrade()
{
m_pSet->Close();
m_pSet->m_strSort = "成绩";
m_pSet->Open();
UpdateData(FALSE);
// TODO: 在此添加命令处理程序代码
}
void Codbc2View::OnRecordDelete()
{
try{m_pSet->Delete();}
catch(CDBException* e)
{ AfxMessageBox(e->m_strError);
e->Delete();
m_pSet->MoveLast();
UpdateData(FALSE);
return ;}
/*if(m_pSet->IsEOF())
m_pSet->MoveLast();
if(m_pSet->IsBOF())
m_pSet->SetFieldNull(NULL);
m_pSet->Requery();
*/
UpdateData(FALSE);
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -