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