最近在做一个小程序,刚开始使用的是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();