c#操做access,update语句不执行的解决办法

update access数据库时,使用了参数化的方式,结果不报错,可是数据也没有更新。后来发现access使用参数化时,参数位置必须和赋值顺序相同才行,不然更新时就会出现数据没法更新可是也不报错的怪现象。
       例如:update tablename set [a]=@a1,[b]=@a2 where [id]=@a3
       那么你在加参数时,也必须先加@a,再加@b,最后加@id.也就是说必需要 
cmd.Parameters.AddWithValue(“@a1”,a);
sql

cmd.Parameters.AddWithValue(“@a2”,b);数据库

cmd.Parameters.AddWithValue(“@a3”,id);spa

       顺序若是错了,就没法更新了。这一点和sql server不同。在sql server中,没必要关心参数增长的顺序。
       由于access在update时参数错位不会报bug,只是不更新,因此这一点在写程序时必定要注意
server