Access数据操作报错:操作必须使用一个可用的更新查询

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

 

转载于:https://www.cnblogs.com/young525/p/5873854.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值