【问题标题】:Can I get the ID of the data that I just inserted?我可以得到我刚刚插入的数据的ID吗?
【发布时间】:2019-11-06 10:48:41
【问题描述】:

所以我想从数据库中的用户订购产品,查询如下:

INSERT INTO [dbo].[Order](UserID, To_Adress, OrderDate, TravelTime, ItemCount, Status, TotalPrice) VALUES (1, 'BIKINI BOTTOM', '20191030 15:00:00', '20191030 15:35:00', 1, 'InTheMaking', 7.50)

下订单后,我想将产品和订单之间的连接放入数据库中,但我必须得到我刚刚创建的OrderID。有没有办法从我刚刚下的订单中获取OrderID

INSERT INTO [dbo].[Order_Product](OrderID, ProductID) VALUES (?[dbo].[Order].OrderID?, 12)

编辑:

好的,所以基本上SCOPE_IDENTITY 是从我的数据库中取出它的方法,但是我如何在第二个INSERT 中使用SCOPE_IDENTITY 同时仍然在同一个查询中?我只需要为此进行 2 个单独的查询吗?

【问题讨论】:

标签: c# sql database


【解决方案1】:

尝试使用 SQL OUTPUT 子句:

INSERT INTO [dbo].[Order](UserID, To_Adress, OrderDate, TravelTime, ItemCount, Status, TotalPrice)
OUTPUT inserted.ID
VALUES (1, 'BIKINI BOTTOM', '20191030 15:00:00', '20191030 15:35:00', 1, 'InTheMaking', 7.50

结合SqlCommand.ExecuteScalar()

【讨论】:

    猜你喜欢
    • 2016-12-30
    • 2011-08-16
    • 2014-04-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-05-14
    • 1970-01-01
    相关资源
    最近更新 更多