参数个数错误(参数化查询)

Posted

技术标签:

【中文标题】参数个数错误(参数化查询)【英文标题】:Wrong number of parameters (parametrized query) 【发布时间】:2011-07-27 09:54:47 【问题描述】:

问:

当我尝试执行以下参数化查询时:

INSERT INTO days (day,short,name,depcode,studycode,batchnum) values (?,?,?,?,?,?);SELECT SCOPE_IDENTITY();

通过command.ExecuteScalar();

抛出以下异常:

错误 [07001] [Informix .NET 提供程序]参数数量错误。

问题出在哪里?

编辑:

 public static int InsertDays(List<Day> days)
        

            int affectedRow = -1;
            Dictionary<string, string> daysParameter = new Dictionary<string, string>();
            try
            
                foreach (Day a in days)
                
                    daysParameter.Add("day", a.DayId.ToString());
                    daysParameter.Add("short", a.ShortName);
                    daysParameter.Add("name", a.Name);
                    daysParameter.Add("depcode", a.DepCode.ToString());
                    daysParameter.Add("studycode", a.StudyCode.ToString());
                    daysParameter.Add("batchnum", a.BatchNum.ToString());

                    affectedRow = DBUtilities.InsertEntity_Return_ID("days", daysParameter);
                    daysParameter.Clear();
                    if (affectedRow < 0)
                    
                        break;
                    
                
            
            catch (Exception ee)
            
                string message = ee.Message;
            

            return affectedRow;

        

public static int InsertEntity_Return_ID(string tblName, Dictionary<string, string> dtParams)
        
            int Result = -1;
            DBConnectionForInformix DAL_Helper = new DBConnectionForInformix("");
            string[] field_names = new string[dtParams.Count];
            dtParams.Keys.CopyTo(field_names, 0);
            string[] field_values = new string[dtParams.Count];
            string[] field_valuesParam = new string[dtParams.Count];
            dtParams.Values.CopyTo(field_values, 0);
            for (int i = 0; i < field_names.Length; i++)
            
                field_valuesParam[i] = "?";
            
            string insertCmd = @"INSERT INTO " + tblName + " (" + string.Join(",", field_names) + ") values (" + string.Join(",", field_valuesParam) + ");SELECT SCOPE_IDENTITY();";

        Result = int.Parse(DAL_Helper.Return_Scalar(insertCmd));
        return Result;
        

【问题讨论】:

不应该是command.ExecuteNonQuery吗? @Eben:由于“SELECT SCOPE_IDENTITY”部分,我怀疑它是 ExecuteScalar。 您在哪里添加了参数值?你应该有很多行添加到command.Parameters... @Eben:不,他正在选择SCOPE_IDENTITY(),所以他希望从那里返回值(您需要向右滚动)。 啊!错过了select。我的坏:) 【参考方案1】:

您尚未显示实际填充参数 的位置。鉴于您有正确数量的问号,我怀疑这就是问题所在。

编辑:好的,现在您已经发布了更多代码,很明显出了什么问题:您的 Return_Scalar 方法不接受任何实际值!在填充 field_values 之后,您不会在任何地方使用。需要在命令中设置参数。

(顺便说一句,你也应该看看.NET naming conventions...)

【讨论】:

@just_name:我已经编辑了我的答案。您实际上并没有告诉数据库要使用什么值。【参考方案2】:

确保您提供参数的位置其中一个值不为空。这可能会导致提供者忽略该参数。如果这是您的问题,请通过 DBNull

编辑

正如 Jon 所说,您需要使用 command.Parameters 为命令提供要在查询中使用的参数。

【讨论】:

以上是关于参数个数错误(参数化查询)的主要内容,如果未能解决你的问题,请参考以下文章

解析参数化查询C#时出错[重复]

MySQL 参数化查询的功能就像它在 C# 应用程序中未参数化一样

参数化查询中的 JavaScript 错误

未提供的参数化查询。实体框架

Oracle 的 C# 参数化查询 - 严重且危险的错误!

来自 .Net 的 Oracle 参数化查询