?? adomfcdlg.cpp
字號(hào):
// ADOMFCDlg.cpp : implementation file
//
#include "stdafx.h"
#include "ADOMFC.h"
#include "ADOMFCDlg.h"
#include <Atlbase.h> //CComVariant
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About
class CAboutDlg : public CDialog
{
public:
CAboutDlg();
// Dialog Data
//{{AFX_DATA(CAboutDlg)
enum { IDD = IDD_ABOUTBOX };
//}}AFX_DATA
// ClassWizard generated virtual function overrides
//{{AFX_VIRTUAL(CAboutDlg)
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
//}}AFX_VIRTUAL
// Implementation
protected:
//{{AFX_MSG(CAboutDlg)
//}}AFX_MSG
DECLARE_MESSAGE_MAP()
};
CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
//{{AFX_DATA_INIT(CAboutDlg)
//}}AFX_DATA_INIT
}
void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CAboutDlg)
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
//{{AFX_MSG_MAP(CAboutDlg)
// No message handlers
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CADOMFCDlg dialog
CADOMFCDlg::CADOMFCDlg(CWnd* pParent /*=NULL*/)
: CDialog(CADOMFCDlg::IDD, pParent)
{
//{{AFX_DATA_INIT(CADOMFCDlg)
m_address = _T("");
m_date = _T("");
m_name = _T("");
m_number = _T("");
m_score = _T("");
//}}AFX_DATA_INIT
// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}
void CADOMFCDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CADOMFCDlg)
DDX_Text(pDX, IDE_ADDRESS, m_address);
DDX_Text(pDX, IDE_DATE, m_date);
DDX_Text(pDX, IDE_NAME, m_name);
DDX_Text(pDX, IDE_NUMBER, m_number);
DDX_Text(pDX, IDE_SCORE, m_score);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CADOMFCDlg, CDialog)
//{{AFX_MSG_MAP(CADOMFCDlg)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_BN_CLICKED(IDC_NEW, OnButtAddNew)
ON_BN_CLICKED(IDC_SAVE, OnButtSave)
ON_BN_CLICKED(IDC_NEXT, OnButtNext)
ON_BN_CLICKED(IDC_PREV, OnButtPrev)
ON_BN_CLICKED(IDC_LAST, OnButtLast)
ON_BN_CLICKED(IDC_FIRST, OnButtFirst)
ON_BN_CLICKED(IDC_DELETE, OnButtDelete)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CADOMFCDlg message handlers
//定義一個(gè)鼠標(biāo)HOOK句柄
HHOOK g_hMouse = NULL;
//安裝鼠標(biāo)鉤子.
//LRESULT CALLBACK MouseProc(int nCode, WPARAM wParam, LPARAM lParam)
//{
// return 1;
//}
BOOL CADOMFCDlg::OnInitDialog()
{
CDialog::OnInitDialog();
// Add "About..." menu item to system menu.
// IDM_ABOUTBOX must be in the system command range.
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000);
CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
CString strAboutMenu;
strAboutMenu.LoadString(IDS_ABOUTBOX);
if (!strAboutMenu.IsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
}
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
// TODO: Add extra initialization here
//創(chuàng)建連接記錄集
m_pCon.CreateInstance(__uuidof(Connection));
//打開字串.
HRESULT hr = m_pCon->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=E:\\VC_mfc\\ADOMFC\\db1.mdb;Persist Security Info=False",
"", "", -1);
//創(chuàng)建保存記錄集
m_pRs.CreateInstance(__uuidof(Recordset));
//打開保存記錄
m_pRs->Open("select * from Test", m_pCon.GetInterfacePtr(), adOpenDynamic,
adLockOptimistic, adCmdText);
//移動(dòng)到第一個(gè)數(shù)據(jù)項(xiàng)
m_pRs->MoveFirst();
//顯示出來
DispFileds();
//安裝一個(gè)鉤子過程,GetCurrentThreadId()獲取當(dāng)前線程id.
// g_hMouse = SetWindowsHookEx(WH_MOUSE, MouseProc, NULL, GetCurrentThreadId());
return TRUE; // return TRUE unless you set the focus to a control
}
void CADOMFCDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialog::OnSysCommand(nID, lParam);
}
}
// If you add a minimize button to your dialog, you will need the code below
// to draw the icon. For MFC applications using the document/view model,
// this is automatically done for you by the framework.
void CADOMFCDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // device context for painting
SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);
// Center icon in client rectangle
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2;
// Draw the icon
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CDialog::OnPaint();
}
}
// The system calls this to obtain the cursor to display while the user drags
// the minimized window.
HCURSOR CADOMFCDlg::OnQueryDragIcon()
{
return (HCURSOR) m_hIcon;
}
//顯示信息
void CADOMFCDlg::DispFileds()
{
//獲取數(shù)據(jù)庫里面的字段名.
m_vFieldValue = m_pRs->GetCollect("NO");
//VARIANT類型生成VC類型
m_strFileValue = (char*)_bstr_t(m_vFieldValue);
//獲取學(xué)號(hào)
m_number = m_strFileValue;
m_vFieldValue.Clear();
m_vFieldValue = m_pRs->GetCollect("NAME");
//判斷看NAME是否為空.
if (m_vFieldValue.vt != VT_NULL)
{
m_strFileValue = (char*)_bstr_t(m_vFieldValue);
}
else
{
m_strFileValue = "";
}
m_name = m_strFileValue;
m_vFieldValue.Clear();
m_vFieldValue = m_pRs->GetCollect("ADDRESS");
if (m_vFieldValue.vt != VT_NULL)
{
m_strFileValue = (char*)_bstr_t(m_vFieldValue);
}
else
{
m_strFileValue = "";
}
m_address = m_strFileValue;
m_vFieldValue.Clear();
m_vFieldValue = m_pRs->GetCollect("DATE");
if (m_vFieldValue.vt != VT_NULL)
{
m_strFileValue = (char*)_bstr_t(m_vFieldValue);
}
else
{
m_strFileValue = "";
}
m_date = m_strFileValue;
m_vFieldValue.Clear();
m_vFieldValue = m_pRs->GetCollect("SCORE");
if (m_vFieldValue.vt != VT_NULL)
{
m_strFileValue = (char*)_bstr_t(m_vFieldValue);
}
else
{
m_strFileValue = "";
}
m_score = m_strFileValue;
m_vFieldValue.Clear();
UpdateData(false);
}
//新建記錄
void CADOMFCDlg::OnButtAddNew()
{
// TODO: Add your control notification handler code here
//把當(dāng)前保存數(shù)據(jù)的指針移動(dòng)到最后一行
m_pRs->MoveLast();
//調(diào)用增加數(shù)據(jù)函數(shù)
m_pRs->AddNew();
//顯示數(shù)據(jù)
DispFileds();
}
//保存新建
void CADOMFCDlg::OnButtSave()
{
// TODO: Add your control notification handler code here
setFileds();
}
//保存新建的記錄
void CADOMFCDlg::setFileds()
{
//初始化對(duì)話框,讀數(shù)據(jù)
UpdateData(true);
//把對(duì)話框里的數(shù)據(jù)讀入數(shù)據(jù)庫表中
//前一個(gè)CComVariant(0)的序號(hào)對(duì)應(yīng)數(shù)據(jù)庫表中字段的序號(hào)
HRESULT hr = m_pRs->put_Collect(CComVariant(0), CComVariant(m_number));
m_pRs->put_Collect(CComVariant(1), CComVariant(m_name));
m_pRs->put_Collect(CComVariant(4), CComVariant(m_score));
m_pRs->put_Collect(CComVariant(3), CComVariant(m_date));
m_pRs->put_Collect(CComVariant(2), CComVariant(m_address));
hr = m_pRs->Update();
MessageBox("添加數(shù)據(jù)成功!");
}
//獲取下一條記錄
void CADOMFCDlg::OnButtNext()
{
// 調(diào)用函數(shù)獲取下一條記錄
m_pRs->MoveNext();
//判斷是否結(jié)束
//rename( "EOF", "adoEOF" )在StdAfx.h進(jìn)行改名.防止和文件的EOF重復(fù)
if (m_pRs->adoEOF == VARIANT_FALSE)
{
DispFileds();
}
else
{
//移到上一條記錄,因?yàn)樵诒碇凶詈笠粭l為空.
m_pRs->MovePrevious();
MessageBox("最后一條記錄!");
}
}
//獲取上一條記錄
void CADOMFCDlg::OnButtPrev()
{
// TODO: Add your control notification handler code here
if (m_pRs->GetBOF() == VARIANT_FALSE)
{
m_pRs->MovePrevious();
if (m_pRs->GetBOF() == VARIANT_FALSE)
{
DispFileds();
}
else
{
return;
}
}
else
{
MessageBox("已經(jīng)是第一條記錄!");
}
}
//獲取最后一條記錄
void CADOMFCDlg::OnButtLast()
{
// TODO: Add your control notification handler code here
//調(diào)用函數(shù)移動(dòng)到最后一條記錄
m_pRs->MoveLast();
// if (m_pRs->adoEOF == VARIANT_FALSE)
// {
DispFileds();
// }
// else
// {
// m_pRs->MovePrevious();
// MessageBox("已經(jīng)是最后一條記錄!");
// }
}
//獲取第一條記錄
void CADOMFCDlg::OnButtFirst()
{
// TODO: Add your control notification handler code here
m_pRs->MoveFirst();
DispFileds();
}
//刪除當(dāng)前記錄
void CADOMFCDlg::OnButtDelete()
{
if (IDOK == MessageBox("是否刪除當(dāng)前數(shù)據(jù)?", "當(dāng)前數(shù)據(jù)",MB_YESNO))
{
//獲取當(dāng)前刪除數(shù)據(jù)
HRESULT hr = m_pRs->Delete(adAffectCurrent);
hr = m_pRs->Update();
}
//移動(dòng)到下一條.
OnButtNext();
}
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -