c#操作access,update语句不执行的解决办法
2013-11-27 21:11
337 查看
update access数据库时,使用了参数化的方式,结果不报错,但是数据也没有更新。后来发现access使用参数化时,参数位置必须和赋值顺序相同才行,否则更新时就会出现数据无法更新但是也不报错的怪现象。
例如:update tablename set [a]=@a1,[b]=@a2 where [id]=@a3
那么你在加参数时,也必须先加@a,再加@b,最后加@id.也就是说必须要
cmd.Parameters.AddWithValue(“@a1”,a);
cmd.Parameters.AddWithValue(“@a2”,b);
cmd.Parameters.AddWithValue(“@a3”,id);
顺序如果错了,就无法更新了。这一点和sql server不一样。在sql server中,不必关心参数增加的顺序。
因为access在update时参数错位不会报bug,只是不更新,所以这一点在写程序时一定要注意
例如:update tablename set [a]=@a1,[b]=@a2 where [id]=@a3
那么你在加参数时,也必须先加@a,再加@b,最后加@id.也就是说必须要
cmd.Parameters.AddWithValue(“@a1”,a);
cmd.Parameters.AddWithValue(“@a2”,b);
cmd.Parameters.AddWithValue(“@a3”,id);
顺序如果错了,就无法更新了。这一点和sql server不一样。在sql server中,不必关心参数增加的顺序。
因为access在update时参数错位不会报bug,只是不更新,所以这一点在写程序时一定要注意
相关文章推荐
- c#操作access,update语句不执行的解决办法
- c#操作access,update语句不执行的解决办法
- c#操作access,update语句不执行的解决办法
- c#操作access,update语句不执行的解决办法
- c#操作access,update语句不执行的解决办法
- C#使用oledb连接excel执行Insert Into语句出现“操作必须使用一个可更新的查询”的解决办法
- c#操作access,出现“内部错误: 无效的参数访问器: 2 BADBINDINFO”的解决办法
- ACCESS中的Update语句不支持Select的解决办法
- oracle执行update语句时卡住问题分析及解决办法
- PLSQL 执行 for update 语句被锁定的解决办法
- C# SQL语句执行时间过长在操作完成之前超时时间已过或服务器未响应问题的解决
- SSH框架中3.0版本不能执行SQL语句update,insert的解决办法。
- C#使用List出现“集合已修改;可能无法执行枚举操作”错误的解决办法
- 转:"为自动填充列调整大小期间不能执行此操作"解决办法 .
- update 语句执行十几小时问题解决
- cocos2d-js:调用scheduleUpdate()不执行update()方法的解决办法
- VC2005:无法执行添加/移除操作,因为代码元素是只读的....多个解决办法
- C#中关于updatePanel与freeTextBox不兼容的问题 当页面刷子新后,ftb不能输入内容的解决办法
- cocos2d-x调用scheduleUpdate()不执行update()方法的解决办法
- 源文件名长度大于文件系统支持的长度。请尝试将其移动到具有较短路径名称的位置,或者在执行此操作前尝试将其重命名为较短的名称--解决办法