asp.net 无法更新ACCESS数据库的问题

下面这一段代码执行时,没有任何提示出错.但是就是无法更新access数据库,,使用MSSQL2005数据库却可以正常使用.

 1 None.gif          public   static   void  UpdateNews( int  id  ,  string  title  ,  string  content  , DateTime publishTime  ,  string  url )
 2 ExpandedBlockStart.gifContractedBlock.gif         dot.gif {
 3InBlock.gif            using (OleDbConnection connection = SqlDataProvider.GetOleDbConnection())
 4ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
 5InBlock.gif                string sqlStr = " UPDATE [News] SET [Title]=@Title, [Content]=@Content, [PublishTime]=@PublishTime, [Url]=@Url WHERE ID=@ID";
 6InBlock.gif
 7InBlock.gif                OleDbCommand command = new OleDbCommand(sqlStr, connection);
 8InBlock.gif
 9InBlock.gif                command.Parameters.Add("@ID", OleDbType.Integer).Value = id;
10InBlock.gif
11InBlock.gif                command.Parameters.Add("@Title", OleDbType.Char).Value = title;
12InBlock.gif    
13InBlock.gif                command.Parameters.Add("@Content", OleDbType.VarWChar).Value = content;
14InBlock.gif    
15InBlock.gif                command.Parameters.Add("@PublishTime", OleDbType.DBDate).Value = publishTime;
16InBlock.gif
17InBlock.gif                command.Parameters.Add("@Url", OleDbType.VarWChar).Value = url;
18InBlock.gif
19InBlock.gif                connection.Open();
20InBlock.gif                command.ExecuteNonQuery();
21InBlock.gif                connection.Close();
22ExpandedSubBlockEnd.gif            }

23ExpandedBlockEnd.gif        }

尝试了好久,发现,在使用ACCESS时。sqlStr里的参数序列必须和下面的command里的参数序列一致才能正常更新,也就是必须把   command.Parameters.Add("@ID", OleDbType.Integer).Value = id;
剪切到17行之后。才能正常运行。
 1 None.gif          public   static   void  UpdateNews( int  id  ,  string  title  ,  string  content  , DateTime publishTime  ,  string  url )
 2 ExpandedBlockStart.gifContractedBlock.gif         dot.gif {
 3InBlock.gif            using (OleDbConnection connection = SqlDataProvider.GetOleDbConnection())
 4ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
 5InBlock.gif                string sqlStr = " UPDATE [News] SET [Title]=@Title, [Content]=@Content, [PublishTime]=@PublishTime, [Url]=@Url WHERE ID=@ID";
 6InBlock.gif
 7InBlock.gif                OleDbCommand command = new OleDbCommand(sqlStr, connection);
 8InBlock.gif        
 9InBlock.gif                command.Parameters.Add("@Title", OleDbType.Char).Value = title;
10InBlock.gif    
11InBlock.gif                command.Parameters.Add("@Content", OleDbType.VarWChar).Value = content;
12InBlock.gif    
13InBlock.gif                command.Parameters.Add("@PublishTime", OleDbType.DBDate).Value = publishTime;
14InBlock.gif
15InBlock.gif                command.Parameters.Add("@Url", OleDbType.VarWChar).Value = url;
16InBlock.gif
17InBlock.gif                command.Parameters.Add("@ID", OleDbType.Integer).Value = id;
18InBlock.gif
19InBlock.gif                connection.Open();
20InBlock.gif                command.ExecuteNonQuery();
21InBlock.gif                connection.Close();
22ExpandedSubBlockEnd.gif            }

23ExpandedBlockEnd.gif        }
不知道这算不算ACCESS的BUG.

转载于:https://www.cnblogs.com/xingch50/archive/2007/07/19/824640.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值