Получение «слишком большого количества параметров» для хранимой процедуры на странице ASPX - PullRequest
2 голосов
/ 30 ноября 2010

У меня проблемы с выяснением этой ошибки. У меня есть сетка на странице ASPX, которая отображает данные из хранимой процедуры в базе данных SQL Server 2008. Когда страница загружается, я получаю следующую ошибку:

"Procedure or function <sp_name> has too many arguments specified."

Вот код для сетки и источника данных:

<asp:GridView ID="GridView1" runat="server" AllowPaging="True" AutoGenerateColumns="False"
        DataSourceID="SqlDataSource1" ShowFooter="True" OnRowDataBound="GridView1_RowDataBound"
        AllowSorting="True">
        <Columns>
            <asp:BoundField DataField="MerchantID" HeaderText="ID" InsertVisible="False" ReadOnly="True"
                SortExpression="MerchantID" />
            <asp:BoundField DataField="MerchantName" HeaderText="Merchant" SortExpression="MerchantName" />
            <asp:BoundField DataField="RapidTuitionID" HeaderText="RapidTuition ID" SortExpression="RapidTuitionID" />
            <asp:BoundField DataField="DateCreated" HeaderText="Enrolled" SortExpression="DateCreated" />
            <asp:TemplateField HeaderText="Commands">
                <ItemTemplate>
                    <asp:LinkButton ID="ImpersonateUserLinkButton" runat="server" OnClick="Command_Click"
                        CommandName="impersonate" CommandArgument='<%# Eval("MerchantID") %>' CssClass="table_command">Impersonate</asp:LinkButton>
                </ItemTemplate>
            </asp:TemplateField>
        </Columns>
        <EmptyDataTemplate>
            No data to display.
        </EmptyDataTemplate>
        <PagerStyle CssClass="pager" />
    </asp:GridView>
    <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:Development %>"
        SelectCommand="sp_GatewayMerchants" SelectCommandType="StoredProcedure">
        <SelectParameters>
            <asp:ControlParameter ControlID="PromotionPlaceHolderTop$StartDate" Name="StartDate"
                DefaultValue="1/1/2010" PropertyName="Text" Type="DateTime" />
            <asp:ControlParameter ControlID="PromotionPlaceHolderTop$EndDate" Name="EndDate"
                DefaultValue="12/31/2010" PropertyName="Text" Type="DateTime" />
            <asp:ControlParameter ControlID="PromotionPlaceHolderTop$StatusActive" DefaultValue="true"
                Name="StatusActive" PropertyName="Checked" Type="Boolean" />
            <asp:ControlParameter ControlID="PromotionPlaceHolderTop$StatusDeactive" DefaultValue="true"
                Name="StatusDeactive" PropertyName="Checked" Type="Boolean" />
        </SelectParameters>
    </asp:SqlDataSource>

Вот код из хранимой процедуры:

ALTER PROCEDURE [dbo].[sp_GatewayMerchants] 
    -- Add the parameters for the stored procedure here
    @StartDate DateTime, 
    @EndDate DateTime,
    @StatusActive bit,
    @StatusDeactive bit
AS
BEGIN
    -- SET NOCOUNT ON added to prevent extra result sets from
    -- interfering with SELECT statements.
    SET NOCOUNT ON;

    -- Insert statements for procedure here
    SELECT 
        m.MerchantID AS [ID],
        m.MerchantName,
        CASE m.StatusFlag WHEN 1 THEN 'Active' ELSE 'Deactive' END AS [Status],
        m.RapidTuitionID,
        m.DateCreated
    FROM
        Merchant m
    WHERE
        (CONVERT(varchar,m.DateCreated,112) BETWEEN CONVERT(varchar,CONVERT(DATETIME,@StartDate,101),112) AND CONVERT(varchar,CONVERT(DATETIME,@EndDate,101),112))
        AND
        (
            (@StatusActive = 1 AND m.StatusFlag = 1)
            OR 
            (@StatusDeactive = 1 AND m.StatusFlag = 0)
        )
    ORDER BY
        m.MerchantName
END

Источник данных передает 4 параметра, а хранимая процедура принимает 4, но при отображении страницы появляется ошибка, упомянутая выше. Я что-то здесь упускаю?

РЕДАКТИРОВАТЬ: Вот код для столбца шаблона. Но я не уверен, как это может вызвать дополнительные параметры для SP.

        protected void Command_Click(object sender, EventArgs e)
    {
        var merchantID = Convert.ToInt32(((LinkButton)sender).CommandArgument);

        switch (((LinkButton)sender).CommandName)
        {
            case "impersonate":
                var gs = GatewaySession.Parse(Page.User.Identity.Name);
                gs.Role = GatewaySession.RoleEnum.Merchant;
                gs.MerchantID = merchantID;
                gs.CustomerID = -1;

                FormsAuthentication.SetAuthCookie(gs.ToString(), false);

                Page.Session["MerchantID"] = gs.MerchantID;

                Response.Redirect("/Merchant/Default.aspx");
                break;
        }
    }

Если я удаляю ASP: LINKBUTTON, код работает. Так почему бы LINKBUTTON вызывать это?

Ответы [ 4 ]

3 голосов
/ 30 ноября 2010

Используйте Profiler и проверьте, какие параметры действительно передаются в SP.

2 голосов
/ 30 ноября 2010

Из вашего кода похоже, что вы передаете 4 параметра, но давайте удостоверимся, что это происходит во время проектирования и выполнения.

Время разработки

В представлении "Дизайн" вашей страницывыберите свой GridView и разверните расширенное меню, щелкнув [>], и выберите обновление схемы.Это может очистить ваши шаблоны элементов, но это должно быть нормально, так как ваш код сохранен в другом месте (например, здесь).

Время выполнения

Подключите событие SqlDataSource.Selecting и проверьте параметры вашей команды врежим отладки.

ASPX

<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:Development %>"
    SelectCommand="sp_GatewayMerchants" SelectCommandType="StoredProcedure"
    OnSelecting=SqlDataSource1_Selecting>
    ...

CS

protected void SqlDataSource1_Selecting(object sender, System.Web.UI.WebControls.SqlDataSourceSelectingEventArgs e) {
    // check e.Command.Parameters
}

РЕДАКТИРОВАНИЕ

Еще одна вещь, которую вы можете попробовать, это установитьDataKeyNames свойство Data

<asp:GridView ID="GridView1" runat="server" AllowPaging="True" AutoGenerateColumns="False"
    DataSourceID="SqlDataSource1" ShowFooter="True" OnRowDataBound="GridView1_RowDataBound"
    AllowSorting="True" DataKeyNames="MerchantID">

РЕДАКТИРОВАТЬ 2

Другие варианты действий:

  1. Когда вы «обновляете» свойстранице, убедитесь, что не используете F5 или нажмите кнопку Обновить.Перейдите в поле адреса вашего браузера и нажмите Enter, чтобы IsPostBack = true
  2. Удалить OnClick, CommandName и CommandArguemnt из объявления LinkButton
0 голосов
/ 30 ноября 2010

Это связано с безопасностью, ваш web.config должен указывать другую настройку строки подключения (дайджест-аутентификация или логин пользователя), в то время как ваша хранимая процедура требует, чтобы один из них проверил безопасность вашей хранимой процедуры.

0 голосов
/ 30 ноября 2010

Попробуйте добавить обработчик события SQLDataSource.Selecting и проверьте, какие параметры передаются хранимой процедуре. Параметры можно найти в SqlDataSourceSelectingEventArgs.Arguments.

GridView может передавать непредвиденные параметры SP.

...