C++实现连接SQL SERVER2008(_ConnectionPtr、_RecordsetPtr、_CommandPtr)

本文档介绍了如何使用C++通过ADO连接SQL SERVER2008数据库,包括创建Connection、Recordset和Command对象,设置连接字符串,以及处理登录失败的情况。文章还展示了连接成功后的界面交互及数据查询、添加、删除、修改操作的基本步骤。
摘要由CSDN通过智能技术生成

一、环境配置

映入ADO动态库:#import "C:\Program Files\Common Files\System\ado\msado15.dll"  no_namespace rename("EOF","EndOfFile") rename("BOF","FirstOfFile")

二、软件界面

三、源码


// testDlg.cpp : 实现文件
//

#include "stdafx.h"
#include "test.h"
#include "testDlg.h"
#include "afxdialogex.h"
#include "UpdateData.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// 用于应用程序“关于”菜单项的 CAboutDlg 对话框

class CAboutDlg : public CDialogEx
{
public:
    CAboutDlg();

// 对话框数据
    enum { IDD = IDD_ABOUTBOX };

    protected:
    virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV 支持

// 实现
protected:
    DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialogEx(CAboutDlg::IDD)
{
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
    CDialogEx::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP()

// CtestDlg 对话框
CtestDlg::CtestDlg(CWnd* pParent /*=NULL*/)
    : CDialogEx(CtestDlg::IDD, pParent)
    , m_sip(_T(""))
    , m_sDatabaseName(_T(""))
    , m_sUserID(_T(""))
    , m_sPasswd(_T(""))
    , m_sPort(_T(""))
{
    m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CtestDlg::DoDataExchange(CDataExchange* pDX)
{
    CDialogEx::DoDataExchange(pDX);
    DDX_Control(pDX, IDC_LIST1, m_list);
    DDX_Control(pDX, IDC_EDIT_IP, m_ip);
    DDX_Control(pDX, IDC_EDIT_DATABASE_NAME, m_databaseName);
    DDX_Control(pDX, IDC_EDIT_USER_ID, m_userID);
    DDX_Control(pDX, IDC_EDIT_PASSWD, m_passwd);
    DDX_Text(pDX, IDC_EDIT_IP, m_sip);
    DDX_Text(pDX, IDC_EDIT_DATABASE_NAME, m_sDatabaseName);
    DDX_Text(pDX, IDC_EDIT_USER_ID, m_sUserID);
    DDX_Text(pDX, IDC_EDIT_PASSWD, m_sPasswd);
    DDX_Control(pDX, IDC_EDIT_PORT, m_port);
    DDX_Text(pDX, IDC_EDIT_PORT, m_sPort);
}

BEGIN_MESSAGE_MAP(CtestDlg, CDialogEx)
    ON_WM_SYSCOMMAND()
    ON_WM_PAINT()
    ON_WM_QUERYDRAGICON()
    ON_BN_CLICKED(IDC_BTN_CONNECT, &CtestDlg::OnBnClickedBtnConnect)
    ON_BN_CLICKED(IDC_BTN_QUERY, &CtestDlg::OnBnClickedBtnQuery)
    ON_BN_CLICKED(IDC_BTN_ADD, &CtestDlg::OnBnClickedBtnAdd)
    ON_BN_CLICKED(IDC_BTN_DELETE, &CtestDlg::OnBnClickedBtnDelete)
    ON_BN_CLICKED(IDC_BTN_MODIFY, &CtestDlg::OnBnClickedBtnModify)
END_MESSAGE_MAP()


// CtestDlg 消息处理程序
BOOL CtestDlg::OnInitDialog()
{
    CDialogEx::OnInitDialog();

    // 将“关于...”菜单项添加到系统菜单中。

    // IDM_ABOUTBOX 必须在系统命令范围内。
    ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
    ASSERT(IDM_ABOUTBOX < 0xF000);

    CMenu* pSysMenu = GetSystemMenu(FALSE);
    if (pSysMenu != NULL)
    {
        BOOL bNameValid;
        CString strAboutMenu;
        bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
        ASSERT(bNameValid);
        if (!strAboutMenu.IsEmpty())
        {
            pSysMenu->AppendMenu(MF_SEPARATOR);
            pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
        }
    }

    // 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
    //  执行此操作
    SetIcon(m_hIcon, TRUE);            // 设置大图标
    SetIcon(m_hIcon, FALSE);        // 设置小图标

    //1. 初始化界面
    iniUI();    

    return TRUE;  // 除非将焦点设置到控件,否则返回 TRUE
}

void CtestDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
    if ((nID & 0xFFF0) == IDM_ABOUTBOX)
    {
        CAboutDlg dlgAbout;
        dlgAbout.DoModal();
    }
    else
    {
        CDialogEx::OnSysCommand(nID, lParam);
    }
}

// 如果向对话框添加最小化按钮,则需要下面的代码
//  来绘制该图标。对于使用文档/视图模型的 MFC 应用程序,
//  这将由框架自动完成。

void CtestDlg::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
    {
        CDialogEx::OnPaint();
    }
}

//当用户拖动最小化窗口时系统调用此函数取得光标
//显示。
HCURSOR CtestDlg::OnQueryDragIcon()
{
    return static_cast<

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mark-puls

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值