簡體   English   中英

嘗試獲取插入的ID時強制轉換無效

[英]cast is invalid when attempting to grab inserted ID

我正在嘗試獲取表的最近插入的ID,但是我一直收到轉換錯誤。 該項目始終包含NULL,但我不確定為什么。 我正在按照位於此處的說明進行操作: http : //www.mikesdotnetting.com/Article/54/Getting-the-identity-of-the-recent-cently-添加的記錄

這是我的SqlDataSource:

<asp:SqlDataSource ID="SqlDataSource2" runat="server" 
    ConnectionString="<%$ ConnectionStrings:NH_SWAGConnectionString %>"             
    InsertCommand="INSERT INTO [tblOrders] ([OrderDate], [OrderTotal], [OrderAccount], [OrderCostCentre]) VALUES (@OrderDate, @OrderTotal, @OrderAccount, @OrderCostCentre); SET @OrderNewID = SCOPE_IDENTITY()" 
    SelectCommand="SELECT * FROM [tblOrders]" 
    UpdateCommand="UPDATE [tblOrders] SET [OrderDate] = @OrderDate, [OrderTotal] = @OrderTotal, [OrderAccount] = @OrderAccount, [OrderCostCentre] = @OrderCostCentre WHERE [OrderID] = @original_OrderID AND [OrderDate] = @original_OrderDate AND [OrderTotal] = @original_OrderTotal AND [OrderAccount] = @original_OrderAccount AND [OrderCostCentre] = @original_OrderCostCentre"            
    ConflictDetection="CompareAllValues" 
    OldValuesParameterFormatString="original_{0}"
    OnInserting="SqlDataSource2_Inserting"
    OnInserted="SqlDataSource2_Inserted">
    <InsertParameters>
        <asp:Parameter Direction="Output" Name="OrderNewId" Type="Int32" />
    </InsertParameters>
    <UpdateParameters>
        <asp:Parameter Name="OrderDate" Type="DateTime" />
        <asp:Parameter Name="OrderTotal" Type="Decimal" />
        <asp:Parameter Name="OrderAccount" Type="String" />
        <asp:Parameter Name="OrderCostCentre" Type="String" />
        <asp:Parameter Name="original_OrderID" Type="Int32" />
        <asp:Parameter Name="original_OrderDate" Type="DateTime" />
        <asp:Parameter Name="original_OrderTotal" Type="Decimal" />
        <asp:Parameter Name="original_OrderAccount" Type="String" />
        <asp:Parameter Name="original_OrderCostCentre" Type="String" />
    </UpdateParameters>
</asp:SqlDataSource>

這是插入新記錄並調用SCOPE_IDENTITY()來獲取新ID的背后代碼:

protected void btnOrder_Click(object sender, EventArgs e)
{
    //Add entry to Order Table    

    SqlDataSource2.InsertParameters.Add("OrderDate", DateTime.Now.ToString("MMMM dd, yyyy"));
    SqlDataSource2.InsertParameters.Add("OrderTotal", "0");
    SqlDataSource2.InsertParameters.Add("OrderAccount", ItmUser);
    SqlDataSource2.InsertParameters.Add("OrderCostCentre", ItmCostCode.Text);

    SqlDataSource2.Insert();
}

protected void SqlDataSource2_Inserted(object sender, SqlDataSourceStatusEventArgs e)
{
    OrderNewID = (int)e.Command.Parameters["@OrderNewId"].Value;
}

為什么上面的@OrderNewId為NULL?

好吧,我明白了。 我沒有使用SET,而是在InsertQuery中使用了SELECT:

INSERT INTO [tblOrders] ([OrderDate], [OrderTotal], [OrderAccount], [OrderCostCentre]) VALUES (@OrderDate, @OrderTotal, @OrderAccount, @OrderCostCentre); SELECT @OrderNewID = SCOPE_IDENTITY()

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM