www.pudn.com > MFC 函数实用手册.rar > CDatabaseTestDlg.cpp


// CDatabaseTestDlg.cpp : 实现文件 
// 
 
#include "stdafx.h" 
#include "CDatabaseTest.h" 
#include "CDatabaseTestDlg.h" 
#include "afxdb.h" 
 
#ifdef _DEBUG 
#define new DEBUG_NEW 
#endif 
 
 
// CCDatabaseTestDlg 对话框 
 
void Database(); 
 
CCDatabaseTestDlg::CCDatabaseTestDlg(CWnd* pParent /*=NULL*/) 
	: CDialog(CCDatabaseTestDlg::IDD, pParent) 
{ 
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); 
} 
 
void CCDatabaseTestDlg::DoDataExchange(CDataExchange* pDX) 
{ 
	CDialog::DoDataExchange(pDX); 
} 
 
BEGIN_MESSAGE_MAP(CCDatabaseTestDlg, CDialog) 
	ON_WM_PAINT() 
	ON_WM_QUERYDRAGICON() 
	//}}AFX_MSG_MAP 
	ON_BN_CLICKED(IDOK, OnBnClickedOk) 
END_MESSAGE_MAP() 
 
 
// CCDatabaseTestDlg 消息处理程序 
 
BOOL CCDatabaseTestDlg::OnInitDialog() 
{ 
	CDialog::OnInitDialog(); 
 
	// 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动 
	//  执行此操作 
	SetIcon(m_hIcon, TRUE);			// 设置大图标 
	SetIcon(m_hIcon, FALSE);		// 设置小图标 
 
	// TODO:在此添加额外的初始化代码 
	 
	return TRUE;  // 除非设置了控件的焦点,否则返回 TRUE 
} 
 
// 如果向对话框添加最小化按钮,则需要下面的代码 
//  来绘制该图标。对于使用文档/视图模型的 MFC 应用程序, 
//  这将由框架自动完成。 
 
void CCDatabaseTestDlg::OnPaint()  
{ 
	if (IsIconic()) 
	{ 
		CPaintDC dc(this); // 用于绘制的设备上下文 
 
		SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0); 
 
		// 使图标在工作矩形中居中 
		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; 
 
		// 绘制图标 
		dc.DrawIcon(x, y, m_hIcon); 
	} 
	else 
	{ 
		CDialog::OnPaint(); 
	} 
} 
 
//当用户拖动最小化窗口时系统调用此函数取得光标显示。 
HCURSOR CCDatabaseTestDlg::OnQueryDragIcon() 
{ 
	return static_cast<HCURSOR>(m_hIcon); 
} 
 
void CCDatabaseTestDlg::OnBnClickedOk() 
{ 
	// TODO: 在此添加控件通知处理程序代码 
	Database(); 
} 
 
class MyRecordset : public CRecordset 
{ 
public: 
	MyRecordset( CDatabase* pDatabase = NULL ); 
	DECLARE_DYNAMIC(MyRecordset) 
	CString m_szName; 
	CString m_szPassword; 
	virtual void DoFieldExchange(CFieldExchange* pFX); 
}; 
 
MyRecordset::MyRecordset( CDatabase* pDatabase) 
		: CRecordset(pDatabase) 
{ 
	m_szName = _T(""); 
	m_szPassword = _T(""); 
} 
 
IMPLEMENT_DYNAMIC(MyRecordset, CRecordset) 
 
void MyRecordset::DoFieldExchange(CFieldExchange* pFX) 
{ 
	//{{AFX_FIELD_MAP(CCustSet) 
	pFX->SetFieldType(CFieldExchange::outputColumn); 
	RFX_Text(pFX, "[username]", m_szName); 
	RFX_Text(pFX, "[password]", m_szPassword); 
	//}}AFX_FIELD_MAP 
} 
 
void Database() 
{ 
	CDatabase db; 
	try 
	{ 
		//if(	db.Open("mytest") ) 
		if(	db.OpenEx("DSN=mytest;") ) 
		{ 
			/*db.SetQueryTimeout(5); 
			AfxMessageBox( db.GetDatabaseName() ); 
			if(!db.CanUpdate()) 
				AfxMessageBox("数据库为只读。"); 
			if(db.CanTransact()) 
				AfxMessageBox("数据库记录集允许事务。");*/ 
			/* //ExecuteSQL Example 
			CString sql = "delete from user where username = 'abc'"; 
			db.ExecuteSQL( sql ); 
			*/ 
			MyRecordset rs(&db); 
			rs.Open(AFX_DB_USE_DEFAULT_TYPE,"select * from user"); 
           if( rs.CanAppend() ) 
			{ 
				AfxMessageBox("here"); 
				rs.AddNew(); 
				rs.m_szName = _T("newname"); 
				rs.m_szPassword = _T("newpassword"); 
			} 
			AfxMessageBox( rs.GetSQL() ); 
			rs.Close(); 
			db.Close(); 
		} 
		else 
		{ 
			AfxMessageBox("无法连接数据库或数据库被其他程序以独占的方式打开。"); 
		} 
	} 
	catch(CDBException* pEx) 
	{ 
		pEx->ReportError(); 
        pEx->Delete(); 
	} 
}