2013-08-23 5 views
0

Я продолжаю получать исключение OleDbException: «Нет значения для одного или нескольких требуемых параметров» - не очень специфично.SqlDataSource InsertCommand Отсутствующие обязательные параметры

Мне не повезло найти решение моей проблемы в Интернете. Я пробовал много разных вещей, например, не объявляя параметры в форме и не создавая их во время выполнения кода.

Вот мой уродливый код:

<asp:sqldatasource ID="datasource" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString %>" ProviderName="<%$ ConnectionStrings:ConnectionString.ProviderName %>" 
    SelectCommand="SELECT [ID], [Test Data] AS Test_Data, [More Data] AS More_Data FROM [Main]" 
    UpdateCommand="UPDATE [Main] SET [Test Data][email protected], [More Data][email protected] WHERE [ID][email protected]" 
    InsertCommand="INSERT INTO [Main] ([ID], [Test Data], [More Data]) VALUES (@InsertID, @InsertTestData, @InsertMoreData)" 
    DeleteCommand="" > 
    <UpdateParameters> 
     <asp:ControlParameter Name="TestData" ControlId="updateTest" PropertyName="Text" /> 
     <asp:ControlParameter Name="MoreData" ControlId="updateMore" PropertyName="Text" /> 
     <asp:ControlParameter Name="InsertTestData" ControlId="insertTest" PropertyName="Text" /> 
     <asp:ControlParameter Name="InsertID" ControlId="insertIDD" PropertyName="SelectedValue" /> 
     <asp:ControlParameter Name="InsertMoreData" ControlId="insertMore" PropertyName="Text" /> 
     <asp:ControlParameter Name="ID" ControlId="DropDownList2" PropertyName="SelectedValue" /> 
    </UpdateParameters> 
</asp:sqldatasource> 

    <asp:GridView ID="GridView1" runat="server" AllowSorting="true" DataSourceID="datasource"></asp:GridView> 
    <br /> 
    <asp:DropDownList ID="insertIDD" DataSourceID="datasource" DataTextField="ID" runat="server" Font-Bold="False"></asp:DropDownList> 
    <asp:TextBox ID="insertTest" runat="server"></asp:TextBox> 
    <asp:TextBox ID="insertMore" runat="server"></asp:TextBox> 
    <asp:Button ID="Button1" runat="server" Text="Insert" OnClick="Insert" /> 
    <br /> 
    <asp:DropDownList ID="DropDownList2" runat="server" DataSourceID="datasource" DataTextField="ID" OnTextChanged="populateDrop" AutoPostBack="true"></asp:DropDownList> 
    <asp:TextBox ID="updateTest" runat="server"></asp:TextBox> 
    <asp:TextBox ID="updateMore" runat="server"></asp:TextBox> 
    <asp:Button ID="Button2" runat="server" Text="Update" OnClick="Update" /> 
    <br /> 
    <asp:Button ID="Button3" runat="server" Text="Delete" OnClick="Delete" />** 

И # Код C Сзади:

namespace WebApplication2 
{ 
public partial class WebForm1 : System.Web.UI.Page 
{ 
    DataView dv = new DataView(); 
    protected void Page_Load(object sender, EventArgs e) 
    { 
     dv = (DataView)datasource.Select(DataSourceSelectArguments.Empty); 
     updateTest.Text = dv[0]["Test_Data"].ToString(); 
     updateMore.Text = dv[0]["More_Data"].ToString(); 
    } 

    protected void Insert(object sender, EventArgs e) 
    { 
     datasource.Insert(); 
    } 

    protected void Update(object sender, EventArgs e) 
    { 
     datasource.Update(); 
     updateTest.Text = ""; 
     updateMore.Text = ""; 
    } 

SELECT, и UPDATE работать без каких-либо проблем. Независимо от того, что я пытаюсь, я не могу заставить команду INSERT INTO быть счастливой. Я уверен, что это что-то простое, что мне не хватает, но любая помощь будет принята с благодарностью, спасибо!

+2

Будет ли это быть причиной у вас нет параметры вставки, вы есть параметры обновления. – OneFineDay

+0

Глупый я знаю, я понимаю, что ты имеешь в виду ... простите мой новичок – Justin

ответ

1

это для обновления:

<UpdateParameters> 
    <asp:ControlParameter Name="TestData" ControlId="updateTest" PropertyName="Text" /> 
    <asp:ControlParameter Name="MoreData" ControlId="updateMore" PropertyName="Text" /> 
    <asp:ControlParameter Name="ID" ControlId="DropDownList2" PropertyName="SelectedValue" /> 
</UpdateParameters> 

и это для вставки

<InsertParameters> 
<asp:ControlParameter Name="InsertTestData" ControlId="insertTest" PropertyName="Text" /> 
    <asp:ControlParameter Name="InsertID" ControlId="insertIDD" PropertyName="SelectedValue" /> 
    <asp:ControlParameter Name="InsertMoreData" ControlId="insertMore" PropertyName="Text" /> 
</InsertParameters> 

В конце:

<asp:sqldatasource ID="datasource" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString %>" ProviderName="<%$ ConnectionStrings:ConnectionString.ProviderName %>" 
SelectCommand="SELECT [ID], [Test Data] AS Test_Data, [More Data] AS More_Data FROM [Main]" 
UpdateCommand="UPDATE [Main] SET [Test Data][email protected], [More Data][email protected] WHERE [ID][email protected]" 
InsertCommand="INSERT INTO [Main] ([ID], [Test Data], [More Data]) VALUES (@InsertID, @InsertTestData, @InsertMoreData)" 
DeleteCommand="" > 
<UpdateParameters> 
    <asp:ControlParameter Name="TestData" ControlId="updateTest" PropertyName="Text" /> 
    <asp:ControlParameter Name="MoreData" ControlId="updateMore" PropertyName="Text" /> 
    <asp:ControlParameter Name="ID" ControlId="DropDownList2" PropertyName="SelectedValue" /> 
</UpdateParameters> 
<InsertParameters> 
<asp:ControlParameter Name="InsertTestData" ControlId="insertTest" PropertyName="Text" /> 
    <asp:ControlParameter Name="InsertID" ControlId="insertIDD" PropertyName="SelectedValue" /> 
    <asp:ControlParameter Name="InsertMoreData" ControlId="insertMore" PropertyName="Text" /> 
</InsertParameters> 
</asp:sqldatasource> 
Смежные вопросы