當談到ASP.NET編碼時,我是一個新手,所以請原諒我,如果我失去了明顯的東西。ORA-01006:綁定變量不存在ASP.NET
我正在寫一個數據輸入頁面,其中我有一個FormView設置爲默認插入來處理插入和我有一個GridView查看錶中的數據,並允許編輯。
GridView的編輯工作完美,但FormView讓我失望。 當我在FormView中點擊插入時,我得到一個ORA-01006:綁定變量不存在。
我正在使用的SQLDataSource指向Oracle數據庫。
我FormView控件的代碼是:
<asp:FormView ID="FormView1" runat="server" CellPadding="4" DataKeyNames="DATAKEY" DataSourceID="Oracle" DefaultMode="Insert" ForeColor="#333333" HorizontalAlign="Left">
<EditRowStyle BackColor="#999999" />
<FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
<HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
<InsertItemTemplate>
<table>
<tr>
<td align="center">Year :</td>
<td width="30px"><asp:TextBox ID="YearTextBox" runat="server" Text='<%# Bind("YEAR") %>'></asp:TextBox><br /></td>
</tr>
<tr>
<td align="center">Week :</td>
<td width="30px"><asp:TextBox ID="WeekTextBox" runat="server" Text='<%# Bind("WEEK") %>'></asp:TextBox><br /></td>
</tr>
<tr>
<td align="center">Store :</td>
<td width="30px"><asp:TextBox ID="StoreTextBox" runat="server" Text='<%# Bind("LOC_LOC_ID") %>'></asp:TextBox><br /></td>
</tr>
<tr>
<td align="center">Brand :</td>
<td width="30px"><asp:TextBox ID="BrandTextBox" runat="server" Text='<%# Bind("BRAND") %>'></asp:TextBox><br /></td>
</tr>
<tr>
<td align="center">CO_WK_PERC :</td>
<td width="30px"><asp:TextBox ID="CoWkPercTextBox" runat="server" Text='<%# Bind("CO_WK_PERC") %>'></asp:TextBox><br /></td>
</tr>
<tr>
<td align="center">CO_STD_PERC :</td>
<td width="30px"><asp:TextBox ID="CoStdPercTextBox" runat="server" Text='<%# Bind("CO_STD_PERC") %>'></asp:TextBox><br /></td>
</tr>
<tr>
<td align="center">INT_WK_PERC :</td>
<td width="30px"><asp:TextBox ID="IntWkPercTextBox" runat="server" Text='<%# Bind("INT_WK_PERC") %>'></asp:TextBox><br /></td>
</tr>
<tr>
<td align="center">INT_STD_PERC :</td>
<td width="30px"><asp:TextBox ID="IntStdPercTextBox" runat="server" Text='<%# Bind("INT_STD_PERC") %>' Enabled='<%# Bind("INT_STD_PERC") %>'></asp:TextBox><br /></td>
</tr>
</table>
<div class="auto-style1">
<asp:LinkButton ID="InsertButton" runat="server" CausesValidation="True" CommandName="Insert" Text="Insert" />
<asp:LinkButton ID="InsertCancelButton" runat="server" CausesValidation="False" CommandName="Cancel" Text="Cancel" />
</div>
</InsertItemTemplate>
<PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
<RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
</asp:FormView>
我的SqlDataSource是:
<asp:SqlDataSource ID="Oracle"
runat="server"
ConnectionString="<%$ ConnectionStrings:ORACLE_IISUSER %>"
DeleteCommand="DELETE FROM "RGP_PLAN_PERC_TEST_BK" WHERE "DATAKEY" = ?"
InsertCommand="INSERT INTO "RGP_PLAN_PERC_TEST_BK" ("YEAR", "WEEK", "BRAND", "CO_WK_PERC", "CO_STD_PERC", "INT_WK_PERC", "INT_STD_PERC", "LOC_LOC_ID", "DATAKEY") VALUES (:YEAR, :WEEK, :BRAND, :CO_WK_PERC, :CO_STD_PERC, :INT_WK_PERC, :INT_STD_PERC, :LOC_LOC_ID, (SELECT (MAX(DATAKEY) +1) FROM RGP_PLAN_PERC_TEST_BK))"
ProviderName="<%$ ConnectionStrings:ORACLE_IISUSER.ProviderName %>"
SelectCommand="SELECT * FROM "RGP_PLAN_PERC_TEST_BK" ORDER BY "YEAR" DESC, "WEEK" DESC, "LOC_LOC_ID""
UpdateCommand="UPDATE "RGP_PLAN_PERC_TEST_BK" SET "YEAR" = :YEAR, "WEEK" = :WEEK, "BRAND" = :BRAND, "CO_WK_PERC" = :CO_WK_PERC, "CO_STD_PERC" = :CO_STD_PERC, "INT_WK_PERC" = :INT_WK_PERC, "INT_STD_PERC" = :INT_STD_PERC, "LOC_LOC_ID" = :LOC_LOC_ID WHERE "DATAKEY" = :DATAKEY" OnSelecting="Oracle_Selecting">
<DeleteParameters>
<asp:Parameter Name="DATAKEY" Type="Decimal" />
</DeleteParameters>
<InsertParameters>
<asp:Parameter Name="YEAR" Type="String" />
<asp:Parameter Name="WEEK" Type="String" />
<asp:Parameter Name="BRAND" Type="String" />
<asp:Parameter Name="CO_WK_PERC" Type="Decimal" />
<asp:Parameter Name="CO_STD_PERC" Type="Decimal" />
<asp:Parameter Name="INT_WK_PERC" Type="Decimal" />
<asp:Parameter Name="INT_STD_PERC" Type="Decimal" />
<asp:Parameter Name="LOC_LOC_ID" Type="String" />
<asp:Parameter Name="DATAKEY" Type="Decimal" />
</InsertParameters>
<UpdateParameters>
<asp:Parameter Name="YEAR" Type="String" />
<asp:Parameter Name="WEEK" Type="String" />
<asp:Parameter Name="BRAND" Type="String" />
<asp:Parameter Name="CO_WK_PERC" Type="Decimal" />
<asp:Parameter Name="CO_STD_PERC" Type="Decimal" />
<asp:Parameter Name="INT_WK_PERC" Type="Decimal" />
<asp:Parameter Name="INT_STD_PERC" Type="Decimal" />
<asp:Parameter Name="LOC_LOC_ID" Type="String" />
<asp:Parameter Name="DATAKEY" Type="Decimal" />
</UpdateParameters>
</asp:SqlDataSource>
我不知道這是否是因爲我沒有正確鏈接FormView的參數?
我希望有人能夠解釋我的問題?
親切的問候
湯姆