ADO编程中执行不了SQL语句(在线等)

acrobatyuer 2009-08-14 02:50:04

_ConnectionPtr m_Connection; //连接对象
_RecordsetPtr m_Recordset; //记录集对象

m_Connection.CreateInstance(__uuidof(Connection));
m_Recordset.CreateInstance(__uuidof(Recordset));

m_Connection->Open("Provider=SQLOLEDB.1;Data Source=Acrobat;Initial Catalog=pubs;User ID=sa;PWD=;
","","",adConnectUnspecified);

.......

//已经做好了绑定的工作,但是执行下面的查询的话,总是提示错误。
//我是通过ADO提供的IADORecordBinding对象去绑定的。


//这个打开应该没有错吧!
//而且做过异常判断,没有提示连接错误啊!
m_Recordset->Open( "SELECT * FROM Employee ORDER BY lname", (_variant_t)m_Connection, adOpenStatic,
adLockOptimistic, adCmdStoredProc)



每次执行都提示一个对话框“参数类型不正确,或不在可以接受的范围之内,或与其他参数冲突。”

很是郁闷呐!
我有用MessageBox效检过一下语句,显示是个正确的SQL语句啊!

上面是我写的程序中主要调用到的代码,各位拜托了,在线等。。。。
...全文
59 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
见习学术士 2009-08-14
  • 打赏
  • 举报
回复

// 执行查询
_RecordsetPtr& CMyDB::GetRecordSet(CString strSql)
{
try
{
_variant_t RecordsAffected;

if( m_pRecordset->GetState() == adStateOpen)
{
m_pRecordset->Close();
}

m_pRecordset->Open((LPCTSTR)strSql,_variant_t((IDispatch*)m_pConnection,true),adOpenStatic,adLockOptimistic,adCmdText);
}
catch(_com_error e)
{
CString errormessage;
errormessage.Format("SQL执行失败!\r\n错误信息:%s SQL:%s",(char*)(e.Description()),(LPCTSTR)strSql);
m_strError = (LPCTSTR)e.Description();
CLog::Log(errormessage);
}
return m_pRecordset;
}
acrobatyuer 2009-08-14
  • 打赏
  • 举报
回复
改过的,不管用啦!

不是那里的问题啊!我改用Connection对象查询的话就没有什么问题啦!
bohut 2009-08-14
  • 打赏
  • 举报
回复
慢了4秒
见习学术士 2009-08-14
  • 打赏
  • 举报
回复
//把
m_Recordset->Open( "SELECT * FROM Employee ORDER BY lname", (_variant_t)m_Connection, adOpenStatic,
adLockOptimistic, adCmdStoredProc)
//改成

m_Recordset->Open( "SELECT * FROM Employee ORDER BY lname", (_variant_t)m_Connection, adOpenStatic,
adLockOptimistic, adCmdText
bohut 2009-08-14
  • 打赏
  • 举报
回复
m_Recordset->Open( "SELECT * FROM Employee ORDER BY lname", (_variant_t)m_Connection, adOpenStatic, adLockOptimistic, adCmdStoredProc)
;
====================================================================
改成:
m_Recordset->Open( "SELECT * FROM Employee ORDER BY lname", (_variant_t)m_Connection, adOpenDynamic,adLockOptimistic, adCmdText);

打开方式不对。
见习学术士 2009-08-14
  • 打赏
  • 举报
回复
//把 
m_Recordset->Open( "SELECT * FROM Employee ORDER BY lname", (_variant_t)m_Connection, adOpenStatic,
adLockOptimistic, adCmdStoredProc)
//改成

m_Recordset->Open( "SELECT * FROM Employee ORDER BY lname", (_variant_t)m_Connection, adOpenStatic,
adLockOptimistic, adCmdText)

16,471

社区成员

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

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

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