VC连接数据库的问题(ADO)在线等待 立结+诚恳

jyg8888 2006-02-21 11:03:33
我写了个利用ADO连接数据库操作的测试程序 很短
=============
#include<iostream.h>
#include<afxwin.h>
#import "c:\program files\common files\system\ado\msado15.dll" no_namespace rename("EOF","adoEOF")
void main()
{
_ConnectionPtr m_Con;
::CoInitialize(NULL);//初始化COM
m_Con=NULL;
HRESULT hr;
hr=m_Con.CreateInstance("ADODB.Connection");//

if(SUCCEEDED(hr))
{::MessageBox(NULL,"OK","gg",0); }

hr=m_Con->Open( "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=E:\\Factory\\VC\\test.mdb","","",adConnectUnspecified);
if(SUCCEEDED(hr))
{::MessageBox(NULL,"OK","gg",0); }
VARIANT VAL;
m_Con->Execute("insert into MAIN (NAME,WAGE) values ('USER1',1111)",&VAL,1);
m_Con->Execute("insert into MAIN (NAME,WAGE) values ('USER2',2222)",&VAL,1);
m_Con->Execute("insert into MAIN (NAME,WAGE) values ('USER3',3333)",&VAL,1);


m_Con->Close();
m_Con=NULL;
CoUninitialize();




}
====================================
但出现一个我难以解释的情况
为什么执行到
m_Con->Execute("insert into MAIN (NAME,WAGE) values ('USER2',2222)",&VAL,1);
就会出现程序异常的错误框而结束呢
我发现
m_Con->Execute("insert into MAIN (NAME,WAGE) values ('USER1',1111)",&VAL,1);
确实是被加到数据库了
请各位前辈帮我看看呐
诚恳跪谢
...全文
115 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
jyg8888 2006-02-21
  • 打赏
  • 举报
回复
不行啊 两位我都实验过了 一样结果
晕 之前小弟有VB上使用ADO的经验
这次虽然在VC上用 很多东西都感觉到眼熟
但也有很多不同点
现在边看VB方面ADO参考看来不行
前辈能否告知小弟 在那边能找到VC上使用ADO的参考吗
MSDN该以什么为关键字啊
如果那为有范例的话最好能给份 大恩大德 铭记在心
我的MAIL JYG_MYSOUL@YAHOO.COM.CN
再次感谢
快乐鹦鹉 2006-02-21
  • 打赏
  • 举报
回复
VARIANT VAL;
m_Con->Execute("insert into MAIN (NAME,WAGE) values ('USER1',1111)",&VAL,1);
VARIANT VAL2;
m_Con->Execute("insert into MAIN (NAME,WAGE) values ('USER2',2222)",&VAL2,1);
试试
joinclear 2006-02-21
  • 打赏
  • 举报
回复
m_Con->Execute("insert into MAIN (NAME,WAGE) values ('USER2',2222)",&RecordsAffected,adCmdText);

这样试试
T97102003 2006-02-21
  • 打赏
  • 举报
回复
NAME是ACCESS保留字,要用[]括起来
cpio 2006-02-21
  • 打赏
  • 举报
回复
用这个试试:

_variant_t val;
Jimmy_Xia 2006-02-21
  • 打赏
  • 举报
回复
加入出错捕获
try
{
m_Con->Execute("insert into MAIN (NAME,WAGE) values ('USER1',1111)",&VAL,1);
m_Con->Execute("insert into MAIN (NAME,WAGE) values ('USER2',2222)",&VAL,1);
m_Con->Execute("insert into MAIN (NAME,WAGE) values ('USER3',3333)",&VAL,1);
}
catch(const _com_error e)
{
AfxMessageBox(e.Description());
long errCode=e.WCode();
if(3127==errCode) AfxMessageBox("表不存在");
else if(3092==errCode) AfxMessageBox("表已经存在");
return FALSE;
}
分析原因
good luck

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧