1

我正在 Visual Studio 2008 中编写一个 ASP.NET(C#) 应用程序并连接到 SQLExpress 2005。

在尝试使用参数化存储过程更新绑定到 SqlDataSource 的 FormView 控件时,我经常收到一个错误屏幕,提示“指定的参数过多”。

在调用 DataSource.Update() 方法之前,我尝试清除列表并手动添加所有参数。我已经使用断点进行了测试,在 Update 方法触发之前,UpdateParameters 集合包含我在存储过程中指定的 8 个参数,因此我知道我的集合符合我的要求。

传入包含 EXEC 语句的 type="text" 更新命令将起作用,但我需要它通过调用过程本身来工作。

有没有其他人遇到过这些“额外的论点”,还是我在玩 EPR 并追逐虚构的变量?

CREATE PROC spUpdateUserProfile
 @UserNameVar nvarchar(256),
 @DisplayNameVar varchar(30),
 @FNameVar varchar(20),
 @LNameVar varchar(20),
 @EmailVar varchar(30)=NULL,
 @LocationVar varchar(100)=NULL,
 @BirthdateVar smalldatetime=NULL,
 @BiographyVar varchar(2000)=NULL

AS

UPDATE UserProfile
SET UserDisplayName = @DisplayNameVar,
 UserFName = @FNameVar,
 UserLName = @LNameVar,
 UserSharedEmail = @EmailVar,
 UserLocation = @LocationVar,
 UserDOB = @BirthdateVar,
 UserBiography = @BiographyVar
WHERE UserProfile.UserID = 
(SELECT UserProfile.UserID FROM UserProfile
JOIN aspnet_Users ON UserProfile.UserID = aspnet_Users.UserId
WHERE aspnet_Users.UserName = @UserNameVar)
4

3 回答 3

0

更改行:WHERE UserProfile.UserID =
for:WHERE UserProfile.UserID IN

于 2010-02-16T07:03:42.840 回答
0

我也遇到过这种情况,但我设法对其进行了排序。

我的更新来自网格。
我的网格是从另一个存储过程填充的。在那个 Select 存储过程中,我将字段名称更改为更用户友好的名称,例如

select AU.UserName [Member],

后来,当我检查时,更新命令正在传递更新存储过程所需的所有参数以及与重命名字段相对应的额外参数。

我从 Select 过程中删除了重命名并更新了 SqlDataSource。现在只有正确数量的字段被传递。

然后我只是重命名了 GridBoundColumn.eg 的 HeaderText 标签

HeaderText="Member"

我使用的是 RadGrid 而不是标准的 GridView,但它似乎也可以在那里工作。

我使用以下方法检查了传递参数的数量:

protected void  SqlDataSource1_Updating(object sender, SqlDataSourceCommandEventArgs e)
{
    for (int x = 0; x <= e.Command.Parameters.Count - 1;x++ )
    {
        string Type = e.Command.Parameters[x].GetType().ToString();
        string Value = e.Command.Parameters[x].ToString();
    }
}

希望这可以帮助

于 2010-03-03T17:51:32.000 回答
0

只是在黑暗中拍摄,直到我们可以看到像 James 所问的一些代码,但是您是否设置了 DataKeyNames 属性?当我开始使用 FormView 和 GridView 时,我使用隐藏字段手动添加了主键值并发送了 DataKeyNames 属性,我认为这导致该值被发送到存储过程两次而不是一次。

只是猜测

编辑:你试过了吗

    UPDATE UserProfile
    SET UserDisplayName = @DisplayNameVar,
      UserFName = @FNameVar,
      UserLName = @LNameVar,
      UserSharedEmail = @EmailVar,
      UserLocation = @LocationVar,
      UserDOB = @BirthdateVar,
      UserBiography = @BiographyVar
    WHERE UserProfile.UserID = aspnet_Users.UserId
      AND aspnet_Users.UserName = @UserNameVar
于 2010-02-16T02:20:52.083 回答