最近在写一个简单的小应用程序,出现了一个让我头疼大半天的问题,搞到最后才弄清楚,原来是OleDbParameters的一个Bug

具体情况如下:

开始我在使用OleDbCommand进行数据库的更新操作,代码如下:

OleDbConnection _SC = new OleDbConnection(this.GetConnectionString());

            
string UpdateSQL = " UPDATE Topic SET topics=@topics where fid=@fid";
            OleDbCommand _CMD 
= new OleDbCommand(UpdateSQL,_SC);

            _CMD.Parameters.Add(
"@fid",OleDbType.Integer).Value = 8;
            _CMD.Parameters.Add(
"@topics",OleDbType.Integer).Value = 28;

            
try 
            { 
                _SC.Open(); 
                _CMD.ExecuteNonQuery(); 
                _SC.Close(); 
            } 
            
catch(Exception ex) 
            { 
                _SC.Close(); 
                
throw ex; 
            } 

代码执行过程中没有出错,但是数据却没有更新,于是我就采用逐步替换的方式来找原因,费了九牛二虎之力才发现个中奥妙,参数的添加居然需要和SQL语句中参数的位置一致,我Faint,将下面的代码

.NET framework 一个关于OleDbParameters的Bug            _CMD.Parameters.Add("@fid",OleDbType.Integer).Value = 8;
.NET framework 一个关于OleDbParameters的Bug            _CMD.Parameters.Add(
"@topics",OleDbType.Integer).Value = 28;
.NET framework 一个关于OleDbParameters的Bug

改成

.NET framework 一个关于OleDbParameters的Bug            _CMD.Parameters.Add("@topics",OleDbType.Integer).Value = 28;
.NET framework 一个关于OleDbParameters的Bug            _CMD.Parameters.Add(
"@fid",OleDbType.Integer).Value = 8;
.NET framework 一个关于OleDbParameters的Bug

就可以正确更新。

用Reflector查看了一下源码,大致能看清楚Framework是按照参数的顺序和具体的SQL进行的匹配,参数的名称并未发生真正的作用。

相关文章:

  • 2021-06-03
  • 2021-05-22
  • 2021-09-30
  • 2021-10-10
  • 2022-01-20
  • 2021-07-13
  • 2021-12-22
猜你喜欢
  • 2022-01-27
  • 2021-08-25
  • 2021-08-06
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-11-19
相关资源
相似解决方案