VS2013的ADO连接SQL Server出现IDispatch error #3092 错误,求解
1个回答
展开全部
1、IDispatch error #3092
在采用ADO访问ACCESS数据库的时候,出现IDispatch error #3092错误的原因之一是在SQL语句中使用了保留关键字。
比如:如果表的名称为User 则会出现该错误。
例如:
success : insert into Acc_Record(loginname,[password]) values ('abc','123')
error #3092 : insert into Acc_Record(loginname,password) values ('abc','123')
再如:
error #3092 : UPDATE table SET value = '53.74' WHERE id=100003
success : UPDATE table SET table.value = '53.74' WHERE id=100003
2、
一般来说,SQL 语句中的字符串常量需要用【单引号】括起来,所以:
CString str;
str.Format("select * from info where 姓名='%s'",strname)
在采用ADO访问ACCESS数据库的时候,出现IDispatch error #3092错误的原因之一是在SQL语句中使用了保留关键字。
比如:如果表的名称为User 则会出现该错误。
例如:
success : insert into Acc_Record(loginname,[password]) values ('abc','123')
error #3092 : insert into Acc_Record(loginname,password) values ('abc','123')
再如:
error #3092 : UPDATE table SET value = '53.74' WHERE id=100003
success : UPDATE table SET table.value = '53.74' WHERE id=100003
2、
一般来说,SQL 语句中的字符串常量需要用【单引号】括起来,所以:
CString str;
str.Format("select * from info where 姓名='%s'",strname)
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询