我不确定它asp:SqlDataSource
的控制是否是ASPxTreeList
我正在使用的 DevExpress 的控制,但是当我尝试使用该Insert()
方法触发存储过程时遇到一个奇怪的错误。
添加节点时,我尝试将节点插入数据库
protected void TagList_NodeInserting(object sender, DevExpress.Web.Data.ASPxDataInsertingEventArgs e)
{
SqlDataTagging.InsertCommandType = SqlDataSourceCommandType.StoredProcedure;
SqlDataTagging.InsertParameters.Add("ParentID", e.NewValues["ParentTag_ID"].ToString());
SqlDataTagging.InsertParameters.Add("TagName", e.NewValues["TagName_VC"].ToString());
SqlDataTagging.InsertParameters.Add("UserID", "1");
SqlDataTagging.InsertCommand = "sp_InsertTag";
SqlDataTagging.Insert();
}
但是,当我触发上述代码时,出现此错误
过程或函数 sp_InsertTag 指定的参数过多。
我的 SP 标头
ALTER PROCEDURE [dbo].[sp_InsertTag] (@ParentID INT, @TagName VARCHAR(100), @UserID int)
但是如您所见,SP 中有 3 个参数,C# 代码中有 3 个参数。
奇怪的是,如果我真的通过文本运行 SQL,例如
SqlDataTagging.InsertCommandType = SqlDataSourceCommandType.Text;
并用 C# 编写 SQL,它将工作......
任何人有任何想法或任何替代方案,所以我可以使用存储过程?
谢谢