Access数据操作报错:操作必须使用一个可用的更新查询
2013-09-18 14:55
330 查看
最近在做一个小程序,刚开始使用的是sql server作为数据库。各个功能设计并验证好后,使用者提出单机使用该该软件。由于sql server安装比较大,而且有时还有点麻烦,为方便软件部署,就将数据库有sql server迁移到access上。
在迁移过程中,程序中access使用sql server上的正确语句,总是报错:“操作必须使用一个可用的更新查询”
在网上找了很多方法都没有解决
后来实在没招了,就重新将sql语句重新书写成最简单的形式,然后再合并,没想到就意外的解决了这个问题。后来才意识access2003无法使用sql嵌套语句,否则就是报错。如:
update test1 set myvalue=(select myvalue from test2 where myid=2) where myid=1
上述这个语句在sql server上可以正常执行的,但在access上就报错,必须改成下面两个分语句
临时变量=select myvalue from test2 where myid=2
update test1 set myvalue=临时量 where myid=1
注意:上面的“临时变量=”并不能直接这样写,只是表示要借助临时变量来完成一个复合的嵌套sql语句。如果你使用C#在.NET上编程,这个临时变量的值就可以使用下面语句得到:
oleDbCommand oleDbCom = new oleDbCommand(" select myvalue from test2 where myid=2" , oleDbConnection);
tempValue = oleDbCom.ExcuteScalar();
在迁移过程中,程序中access使用sql server上的正确语句,总是报错:“操作必须使用一个可用的更新查询”
在网上找了很多方法都没有解决
后来实在没招了,就重新将sql语句重新书写成最简单的形式,然后再合并,没想到就意外的解决了这个问题。后来才意识access2003无法使用sql嵌套语句,否则就是报错。如:
update test1 set myvalue=(select myvalue from test2 where myid=2) where myid=1
上述这个语句在sql server上可以正常执行的,但在access上就报错,必须改成下面两个分语句
临时变量=select myvalue from test2 where myid=2
update test1 set myvalue=临时量 where myid=1
注意:上面的“临时变量=”并不能直接这样写,只是表示要借助临时变量来完成一个复合的嵌套sql语句。如果你使用C#在.NET上编程,这个临时变量的值就可以使用下面语句得到:
oleDbCommand oleDbCom = new oleDbCommand(" select myvalue from test2 where myid=2" , oleDbConnection);
tempValue = oleDbCom.ExcuteScalar();
相关文章推荐
- Asp.net连Access时:操作必须使用一个可更新的查询
- access操作必须使用一个可更新的查询
- Access update语句 提示 "操作必须使用一个可更新的查询"Access update语句 提示 "操作必须使用一个可更新的查询"
- 〔问题〕Microsoft OLE DB Provider for ODBC Drivers (0x80004005)[Microsoft][ODBC Microsoft Access Driver] 操作必须使用一个可更新的查询
- [Microsoft][ODBC Microsoft Access Driver] 操作必须使用一个可更新的查询(解决办法)
- Access里的错误-操作必须使用一个可更新的查询
- asp+access中 打开网页时出现“操作必须使用一个可更新的查询”原因及解决办法
- access提示:操作必须使用一个可更新的查询
- Access中"操作必须使用一个可更新的查询"错误的解决办法
- Access中"操作必须使用一个可更新的查询"错误的解决办法
- asp.net access 操作必须使用一个可更新的查询
- ASP.NET_ACCESS_操作必须使用一个可更新的查询
- Access操作必须使用一个可更新的查询
- Access操作必须使用一个可更新的查询
- Access提示“操作必须使用一个可更新的查询”的解决办法
- “[Microsoft][ODBC Microsoft Access Driver] 操作必须使用一个可更新的查询”的解决办法
- 解决"操作必须使用一个可更新的查询"问题
- C#使用oledb连接excel运行Insert Into语句出现“操作必须使用一个可更新的查询”的解决的方法
- C#ADO连接修改Paradox表时“操作必须使用一个可更新的查询”错误的处理办法
- ado.net 操作excel 问题记录 -- 操作必须使用一个可更新的查询