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

📄

📁 一个数据库应用程序
💻
字号:
// 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 + -