ADO连接数据库,添加,删除,修改老是RunTIME error!请大家帮忙啊

#include "stdafx.h"
#include "QD1.h"
#include "QD1Dlg.h"

#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()

/
// CQD1Dlg dialog

CQD1Dlg::CQD1Dlg(CWnd* pParent /*=NULL*/)
 : CDialog(CQD1Dlg::IDD, pParent)
{
 //{{AFX_DATA_INIT(CQD1Dlg)
  // NOTE: the ClassWizard will add member initialization here
 //}}AFX_DATA_INIT
 // Note that LoadIcon does not require a subsequent DestroyIcon in Win32
 m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CQD1Dlg::DoDataExchange(CDataExchange* pDX)
{
 CDialog::DoDataExchange(pDX);
 //{{AFX_DATA_MAP(CQD1Dlg)
  // NOTE: the ClassWizard will add DDX and DDV calls here
 //}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CQD1Dlg, CDialog)
 //{{AFX_MSG_MAP(CQD1Dlg)
 ON_WM_SYSCOMMAND()
 ON_WM_PAINT()
 ON_WM_QUERYDRAGICON()
 ON_BN_CLICKED(IDC_BUTTON1, OnButton1)
 ON_BN_CLICKED(IDC_BUTTON2, OnButton2)
 ON_BN_CLICKED(IDC_BUTTON3, OnButton3)
 ON_BN_CLICKED(IDC_BUTTON4, OnButton4)
 //}}AFX_MSG_MAP
END_MESSAGE_MAP()

/
// CQD1Dlg message handlers

BOOL CQD1Dlg::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
 
 return TRUE;  // return TRUE  unless you set the focus to a control
}

void CQD1Dlg::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 CQD1Dlg::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 CQD1Dlg::OnQueryDragIcon()
{
 return (HCURSOR) m_hIcon;
}

void CQD1Dlg::OnButton1()
{
 // TODO: Add your control notification handler code here
// TODO: Add your control notification handler code here
 CString sSql;
 GetDlgItem(IDC_EDIT1)->GetWindowText(aa);
 CoInitialize(NULL);
    _ConnectionPtr pConn(__uuidof(Connection));
 _RecordsetPtr pRst(__uuidof(Recordset));
    pConn->ConnectionString="Provider=SQLOLEDB.1;Persist Security Info=true;Integrated Security=SSPI;Initial Catalog=QingDao";
 pConn->Open("","","",adConnectUnspecified);
 
 
 sSql.Format("SELECT * FROM jieshao WHERE Question like '%s'",aa);
 pRst->Open(_bstr_t(sSql),_variant_t((IDispatch*)pConn),adOpenDynamic,adLockOptimistic,adCmdText); 
 
 GetDlgItem(IDC_EDIT2)->SetWindowText((_bstr_t)pRst->GetCollect("Answer"));
 
 pRst->Close();
    pConn->Close();
    pRst.Release();
    pConn.Release();
    CoUninitialize();
}

void CQD1Dlg::OnButton2()
{
 // TODO: Add your control notification handler code here
   
 CString   sSql;
    tt[0]="W130";
 tt[1]="W131";
 tt[2]="W132";
 tt[3]="W133";
 tt[4]="W134";
 tt[5]="W135";
 tt[6]="W136";
    tt[7]="W138";
    tt[8]="W139";
    tt[9]="W140";

 //char tt[10000];

 CoInitialize(NULL);
    _ConnectionPtr pConn(__uuidof(Connection));
    _RecordsetPtr pRst(__uuidof(Recordset));
    pConn->ConnectionString="Provider=SQLOLEDB.1;Persist Security Info=False;Initial Catalog=QingDao";
   // pConn->Open("","","",adConnectUnspecified);
    pConn->Open(_bstr_t(sSql),"","",adModeUnknown);

 
// MessageBox("打开成功");
    


     GetDlgItem(IDC_EDIT1)->GetWindowText(aa);
     GetDlgItem(IDC_EDIT2)->GetWindowText(bb);
  
   // m_edit1.GetWindowText(aa);
    //m_edit2.GetWindowText(bb);

    //ppdlg->m_edit1.SetWindowText(aa);
    //ppdlg->Question[y++]=aa;
 
 // ss[0]=aa;


 sSql.Format("INSERT INTO jieshao(jieshao_id,Question,Answer)  VALUES ('%s','%s','%s')",tt[i++],aa,bb);
 
 _variant_t RecordsAffected;
 
 pConn->Execute(_bstr_t(sSql),&RecordsAffected,adCmdText);

 MessageBox("添加完成");              

// pRst->Close();
    pConn->Close();
//  pRst.Release(); 
    pConn.Release();
    CoUninitialize();

 /*   CoInitialize(NULL);
    _ConnectionPtr m_pConnection;
 m_pConnection.CreateInstance(_uuidof(Connection)); //初始化Connection指针

 _bstr_t strConnect ="Provider=SQLOLEDB.1;Server=//20100815-1858-MSSQLServer;Database=QiangDao;uid=sa;pwd=sa";
    m_pConnection->Open(strConnect,"","",adModeUnknown);

      CString str1,str2,strSql;
   GetDlgItem(IDC_EDIT1)->GetWindowText(str1);
    GetDlgItem(IDC_EDIT2)->GetWindowText(str2);
      strSql.Format("INSERT INTO jieshao  VALUES (122,'%s','%s') ",str1,str2);
 _variant_t RecordsAffected;
   m_pConnection->Execute(_bstr_t(strSql),&RecordsAffected,adCmdText);
   //BSTR bstrSQL = strSql.AllocSysString();
  MessageBox("添加完成");

  m_pConnection->Close();
  m_pConnection = NULL;*/

}

void CQD1Dlg::OnButton3()
{
 // TODO: Add your control notification handler code here
    CString sSql;
 GetDlgItem(IDC_EDIT1)->GetWindowText(aa);
    GetDlgItem(IDC_EDIT2)->GetWindowText(bb);
 
 CoInitialize(NULL);
    _ConnectionPtr pConn(__uuidof(Connection));
    _RecordsetPtr pRst(__uuidof(Recordset));
    pConn->ConnectionString="Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;Initial Catalog=QingDao";
    pConn->Open("","","",-1);
  sSql.Format("UPDATE jieshao SET Question='aa' and Answer='bb'");
 
 _variant_t RecordsAffected;
 
 pConn->Execute(_bstr_t(sSql),&RecordsAffected,adCmdText);

 MessageBox("修改完成");              

// pRst->Close();
    pConn->Close();
//  pRst.Release(); 
    pConn.Release();
    CoUninitialize(); 
}

void CQD1Dlg::OnButton4()
{
 // TODO: Add your control notification handler code here
 CoInitialize(NULL);
_ConnectionPtr pConn(__uuidof(Connection));
_RecordsetPtr pRst(__uuidof(Recordset));
_CommandPtr pCmd(__uuidof(Command));
_variant_t RecordsAffected;    //申请一个_variant_t类型的的变量

pConn->ConnectionString="Provider=SQLOLEDB.1;Data source=QingDao";
pConn->Open("","","",adConnectUnspecified);

pRst=pConn->Execute("DELETE FROM jieshao WHERE Question=''aa",&RecordsAffected,adCmdText);

pConn->Close();
pCmd.Release();
pRst.Release();
pConn.Release();
CoUninitialize();
 /*CoInitialize(NULL);
_ConnectionPtr pConn(__uuidof(Connection));
_RecordsetPtr pRst(__uuidof(Recordset));
_CommandPtr pCmd(__uuidof(Command));
_variant_t RecordsAffected;//申请一个_variant_t类型的的变量


pConn->ConnectionString="Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;Initial Catalog=QingDao";;
pConn->Open("","","",adConnectUnspecified);

pRst=pConn->Execute("DELETE FROM jieshao WHERE Question like'%aa'and Answer like'%bb'",&RecordsAffected,adCmdText);
 
MessageBox("删除成功");   
 
pConn->Close();
pCmd.Release();
pRst.Release();
pConn.Release();
CoUninitialize();*/
}

void CQD1Dlg::OnCancel()
{
 // TODO: Add extra cleanup here
 
 CDialog::OnCancel();
}
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值