ORA-01008: привязаны не все переменные - Веб-приложение ASP.net - PullRequest
0 голосов
/ 07 февраля 2019

Я получаю эту ошибку «ORA-01008: не все переменные привязаны» в запросе на вставку, когда я пытаюсь вставить данные в базу данных Oracle, используя шаблон нижнего колонтитула GridView для вставки данных в базу данных Oracle, я протестировал запрос на сервереи он работает просто отлично, но когда я пытаюсь запустить приложение и выполнить запрос с помощью кнопки добавления, появляется сообщение об ошибке

** Код вида сетки использует поля шаблона, поэтому я могу редактировать вид сетки в шаблоне нижнего колонтитула**

<asp:GridView ID="gvmb"  runat="server" AutoGenerateColumns="False"  BackColor="#DEBA84"  BorderColor="#DEBA84" BorderStyle="None" BorderWidth="1px" CellPadding="3" CellSpacing="2" Width="60%" style="margin-left: 350px" Height="226px" ShowFooter="True" OnRowCommand="gvmb_RowCommand" DataKeyNames="member_id" ShowHeaderWhenEmpty="True">
                <FooterStyle BackColor="#F7DFB5" ForeColor="#8C4510" />
                <HeaderStyle BackColor="#A55129" Font-Bold="True" ForeColor="White" />
                <PagerStyle ForeColor="#8C4510" HorizontalAlign="Center" />
                <RowStyle BackColor="#FFF7E7" ForeColor="#8C4510" />
                <SelectedRowStyle BackColor="#738A9C" Font-Bold="True" ForeColor="White" />
                <SortedAscendingCellStyle BackColor="#FFF1D4" />
                <SortedAscendingHeaderStyle BackColor="#B95C30" />
                <SortedDescendingCellStyle BackColor="#F1E5CE" />
                <SortedDescendingHeaderStyle BackColor="#93451F" />
                <Columns>
                    <asp:TemplateField HeaderText="id">
                        <ItemTemplate>
                            <asp:Label text='<%# Eval("member_id") %>' runat="server"></asp:Label>
                        </ItemTemplate>
                        <EditItemTemplate>
                            <asp:TextBox ID="member" text='<%# Eval("member_id") %>' runat="server">

                            </asp:TextBox>
                        </EditItemTemplate>
                        <FooterTemplate>
                                     <asp:TextBox ID="member_idfooter"  runat="server">

                            </asp:TextBox>
                        </FooterTemplate>
                    </asp:TemplateField>
                    <asp:TemplateField HeaderText="Name">
                        <ItemTemplate>
                            <asp:Label text='<%# Eval("user_name") %>' runat="server"></asp:Label>
                        </ItemTemplate>
                        <EditItemTemplate>
                            <asp:TextBox ID="uname" text='<%# Eval("user_name") %>' runat="server">

                            </asp:TextBox>
                        </EditItemTemplate>
                         <FooterTemplate>
                                     <asp:TextBox ID="user_namefooter" runat="server">

                            </asp:TextBox>
                        </FooterTemplate>
                    </asp:TemplateField>
                    <asp:TemplateField HeaderText="address">
                        <ItemTemplate>
                            <asp:Label text='<%# Eval("address") %>' runat="server"></asp:Label>
                        </ItemTemplate>
                        <EditItemTemplate>
                            <asp:TextBox ID="addres" text='<%# Eval("address") %>' runat="server">

                            </asp:TextBox>
                        </EditItemTemplate>
                         <FooterTemplate>
                                     <asp:TextBox ID="addressfooter" runat="server">

                            </asp:TextBox>
                        </FooterTemplate>
                    </asp:TemplateField>

                    <asp:TemplateField HeaderText="Email">
                        <ItemTemplate>
                            <asp:Label text='<%# Eval("email_address") %>' runat="server"></asp:Label>
                        </ItemTemplate>
                        <EditItemTemplate>
                            <asp:TextBox ID="email" text='<%# Eval("email_address") %>' runat="server">

                            </asp:TextBox>
                        </EditItemTemplate>
                         <FooterTemplate>
                                     <asp:TextBox ID="email_addressfooter" runat="server">

                            </asp:TextBox>
                        </FooterTemplate>
                    </asp:TemplateField>

                    <asp:TemplateField HeaderText="password">
                        <ItemTemplate>
                            <asp:Label text='<%# Eval("password") %>' runat="server"></asp:Label>
                        </ItemTemplate>
                        <EditItemTemplate>
                            <asp:TextBox ID="pass" text='<%# Eval("password") %>' runat="server">

                            </asp:TextBox>
                        </EditItemTemplate>
                         <FooterTemplate>
                                     <asp:TextBox ID="passwordfooter" runat="server">

                            </asp:TextBox>
                        </FooterTemplate>
                    </asp:TemplateField>
                    <asp:TemplateField HeaderText="mobile number">
                        <ItemTemplate>
                            <asp:Label text='<%# Eval("mob_number") %>' runat="server"></asp:Label>
                        </ItemTemplate>
                        <EditItemTemplate>
                            <asp:TextBox ID="mob" text='<%# Eval("mob_number") %>' runat="server">

                            </asp:TextBox>
                        </EditItemTemplate>
                         <FooterTemplate>
                                     <asp:TextBox ID="mob_numberfooter" runat="server">

                            </asp:TextBox>
                        </FooterTemplate>
                    </asp:TemplateField>

                    <asp:TemplateField>
                        <ItemTemplate>
                            <asp:LinkButton ID="edit" runat="server" CommandName="edit" ToolTip="Edit">Edit</asp:LinkButton>
                              <asp:LinkButton ID="delete" runat="server" CommandName="delete" ToolTip="Delete">Delete</asp:LinkButton>

                        </ItemTemplate> 

                        <FooterTemplate>
                             <asp:LinkButton ID="add" runat="server" CommandName="add" ToolTip="add">add</asp:LinkButton>

                        </FooterTemplate>
                    </asp:TemplateField>

                </Columns>
            </asp:GridView>
            <br />
            <asp:Label Text="" ID="lblsuccess" runat="server" ForeColor="Green"></asp:Label>
            <br />
            <asp:Label Text="" ID="lblerror" runat="server" ForeColor="red"></asp:Label>
    </div>

C # код, включая событие вставки. Я получаю сообщение об ошибке в методе add.ExcuteNonQuery ()

 if (e.CommandName.Equals("add"))
            {
                coon.Open();
                string query = "INSERT INTO members (member_id, user_name,address ,mob_number,email_address,password ) VALUES (:member_id, :user_name,:address ,:mob_number,:email_address,:password)";
                OleDbCommand add = new OleDbCommand(query, coon);
                add.Parameters.AddWithValue(":member_id", (gvmb.FooterRow.FindControl("member_idfooter") as TextBox).Text.Trim());
                add.Parameters.AddWithValue(":user_name", (gvmb.FooterRow.FindControl("user_namefooter") as TextBox).Text.Trim());
                add.Parameters.AddWithValue(":address", (gvmb.FooterRow.FindControl("addressfooter") as TextBox).Text.Trim());
                add.Parameters.AddWithValue(":mob_number", (gvmb.FooterRow.FindControl("mob_numberfooter") as TextBox).Text.Trim());
                add.Parameters.AddWithValue(":email_address", (gvmb.FooterRow.FindControl("email_addressfooter") as TextBox).Text.Trim());
                add.Parameters.AddWithValue(":password", (gvmb.FooterRow.FindControl("passwordfooter") as TextBox).Text.Trim());

                add.ExecuteNonQuery();
                fillmembers();
                lblsuccess.Text = "New Recored Added";
                lblerror.Text = "";
                coon.Close();
            }

Ответы [ 2 ]

0 голосов
/ 07 февраля 2019

Решено Я только что изменил: параметры в запросе на?и это сработало, я думаю, что-то не так с последовательностью параметров

INSERT INTO членов (member_id, user_name, address, mob_number, email_address, пароль) VALUES (?,?,?,?,?,?)

0 голосов
/ 07 февраля 2019

Если вы можете переключиться на использование OracleCommand вместо этого, вы можете использовать OracleParamater, специфичный для Oracle, чтобы это работало.

cmd.Parameters.Add(new OracleParameter("client", client));

В зависимости от того, какое у вас пространство имен, Oracle.DataAccess.Client или System.Data.OracleClient, вы можете использовать версию AddWithValue.

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