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

📄 remotedb.cpp

📁 访问远程数据库MS SQLServer实例
💻 CPP
字号:
// RemoteDB.cpp : Defines the class behaviors for the application.
//

#include "stdafx.h"
#include "RemoteDB.h"
#include "RemoteDBDlg.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif












/////////////////////////////////////////////////////////////////////////////
// CRemoteDBApp

BEGIN_MESSAGE_MAP(CRemoteDBApp, CWinApp)
	//{{AFX_MSG_MAP(CRemoteDBApp)
		// NOTE - the ClassWizard will add and remove mapping macros here.
		//    DO NOT EDIT what you see in these blocks of generated code!
	//}}AFX_MSG
	ON_COMMAND(ID_HELP, CWinApp::OnHelp)
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CRemoteDBApp construction

CRemoteDBApp::CRemoteDBApp()
{
	// TODO: add construction code here,
	// Place all significant initialization in InitInstance
}

/////////////////////////////////////////////////////////////////////////////
// The one and only CRemoteDBApp object

CRemoteDBApp theApp;

/////////////////////////////////////////////////////////////////////////////
// CRemoteDBApp initialization

BOOL CRemoteDBApp::InitInstance()
{
	AfxEnableControlContainer();

	// Standard initialization
	// If you are not using these features and wish to reduce the size
	//  of your final executable, you should remove from the following
	//  the specific initialization routines you do not need.

#ifdef _AFXDLL
	Enable3dControls();			// Call this when using MFC in a shared DLL
#else
	Enable3dControlsStatic();	// Call this when linking to MFC statically
#endif

//////////////////////////////////////////////////////////////////////////////
//初始化COM,创建ADO连接等操作
//////////////////////////////////////////////////////////////////////////////
	AfxOleInit();
	m_pConnection.CreateInstance(__uuidof(Connection));
	//在ADO操作中建议语句中要常用try...catch()来捕获错误信息,
	//因为它有时会经常出现一些想不到的错误
	try                 
	{	
	
		//打开172.16.80.85上的SQL数据库DEMO
		m_pConnection->Open("driver={SQL Server};Server=172.16.80.85;DATABASE=DEMO,UID=sa,PWD=sa","","",adModeUnknown);

		//打开本地上的SQL数据库DEMO
		//m_pConnection->Open("driver={SQL Server};Server=(local);DATABASE=DEMO","","",adModeUnknown);

		//打开本地上的ACCESS数据库DEMO
		//m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=DEMO.mdb","","",adModeUnknown);


	}
	catch(_com_error e)
	{
		AfxMessageBox("数据库连接失败,确认数据库是否在当前路径下!");
		return FALSE;
	} 
	try
	{
		m_pCommand.CreateInstance(__uuidof(Command));
		m_pRecordset.CreateInstance(__uuidof(Recordset));
	}
	catch (_com_error &e)
	{
		AfxMessageBox("创立_CommandPtr和_RecordsetPtr实例失败!");
		AfxMessageBox(e.ErrorMessage()); 
	}
//////////////////////////////////////////////////////////////////////////////
	CRemoteDBDlg dlg;
	m_pMainWnd = &dlg;
	int nResponse = dlg.DoModal();
	if (nResponse == IDOK)
	{
		// TODO: Place code here to handle when the dialog is
		//  dismissed with OK
	}
	else if (nResponse == IDCANCEL)
	{
		// TODO: Place code here to handle when the dialog is
		//  dismissed with Cancel
	}

	// Since the dialog has been closed, return FALSE so that we exit the
	//  application, rather than start the application's message pump.
	return FALSE;
}

int CRemoteDBApp::ExitInstance() 
{
	// TODO: Add your specialized code here and/or call the base class
	// 关闭ADO连接状态
	if(m_pConnection->State)
		m_pConnection->Close();
	m_pConnection= NULL;

	if( m_pCommand->State )
		m_pCommand->Release();
	m_pCommand = NULL;

	if( m_pRecordset->State )
 		m_pRecordset->Close();
 	m_pRecordset = NULL;
	
	
	return CWinApp::ExitInstance();
}

//执行SQL语句
_RecordsetPtr CRemoteDBApp::ExcuteCommandADO(CString strSQL)
{
	if(strSQL == "")
		{
			AfxMessageBox("空SQL语句!");
			return NULL;
		}
	_bstr_t strQuery=strSQL;

	try
	{
		m_pCommand->ActiveConnection=m_pConnection;
		m_pCommand->CommandText = strQuery;
		m_pRecordset = m_pCommand->Execute(NULL,NULL,adCmdText);
	}
	catch(_com_error &e)
	{
		CString strErr;
		strErr="执行"+strSQL+"语句失败";
		AfxMessageBox(strErr);
		AfxMessageBox(e.ErrorMessage());// 错误信息
		AfxMessageBox(e.Source());// 错误源
		AfxMessageBox(e.Description());// 错误描述

	}
	return m_pRecordset;
}



⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -