удалить из gridview с помощью хранимой процедуры - PullRequest
0 голосов
/ 04 октября 2009

Привет, у меня есть gridview, связанный с sqldatasource. Я добавил хранимую процедуру для удаления из нескольких таблиц, а затем включил удаление в смарт-теге gridviews.

Когда я нажимаю кнопку удаления, я получаю сообщение об ошибке «Объект должен реализовывать IConvertible». Я прочитал, что это проблема передачи параметра в хранимую процедуру, возможно, передан неправильный тип данных. Я не уверен, передаю ли я параметр хранимой процедуре вообще. Параметр должен быть именем_элемента gridviews, в данном случае это "UserId".

Хранимая процедура отлично работает в Management Studio, поэтому я думаю, что это просто параметр, который передается (или, возможно, не передается)

Нужно ли мне кодировать параметр в коде, чтобы передать его в хранимую процедуру?

<asp:SqlDataSource ID="selectUsers" runat="server" ConnectionString="<%$ ConnectionStrings:CASSFConnectionString %>"
        SelectCommand="SELECT aspnet_Membership.UserId, aspnet_Membership.IsLockedOut, aspnet_Membership.Email, aspnet_Membership.CreateDate, aspnet_Membership.LastLoginDate, aspnet_Membership.LastPasswordChangedDate, aspnet_Profile.PropertyValuesString, aspnet_Users.UserName, aspnet_Membership.IsApproved FROM aspnet_Membership INNER JOIN aspnet_Profile ON aspnet_Membership.UserId = aspnet_Profile.UserId INNER JOIN aspnet_Users ON aspnet_Membership.UserId = aspnet_Users.UserId AND aspnet_Profile.UserId = aspnet_Users.UserId WHERE (CONVERT (nvarchar(256), aspnet_Profile.PropertyValuesString) = @district)" 
        DeleteCommand="DeleteUsers" DeleteCommandType="StoredProcedure" UpdateCommand="UPDATE [aspnet_Membership] SET [IsApproved] = @IsApproved, [Email] = @email, [IsLockedOut] = @IsLockedOut WHERE [aspnet_Membership].[UserId] = @UserID">
        <SelectParameters>
            <asp:ControlParameter ControlID="DropDownList1" Name="district" PropertyName="SelectedValue" />
        </SelectParameters>
        <DeleteParameters>
            <asp:Parameter Name="UserId" Type="String" />
        </DeleteParameters>
        <UpdateParameters>
            <asp:Parameter Name="IsApproved" />
            <asp:Parameter Name="email" />
            <asp:Parameter Name="IsLockedOut" />
            <asp:Parameter Name="UserID" />
        </UpdateParameters>
    </asp:SqlDataSource>

1 Ответ

0 голосов
/ 05 октября 2009

Нашел ответ, мне просто нужно было удалить Type="String" из параметра удаления.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...