簡體   English   中英

sql-server插入語句輸出子句不起作用

[英]sql-server insert statement output clause doesnt work

我做了一些研究,發現獲取新插入的行的ID的最佳解決方案是output子句。我是第一次使用insert語句output子句,無法弄清楚。

這是我的SQL代碼。 這個sql怎么了?

ALTER PROCEDURE [dbo].[MedBul_Insert_Message]      
                                              (@ParentID int, @MessageFrom varchar(500),@MessageTo varchar(500), @MessageSubject varchar(500),@MessageBody varchar(4000),@MessageIsRead int)
AS
BEGIN
    SET LANGUAGE Turkish;

Declare @message_id table (MessageID int);

insert into Messages output INSERTED.ID INTO @message_id (ParentID ,MessageFrom ,MessageSubject ,MessageBody ,MessageIsRead ) values(@ParentID ,@MessageFrom ,@MessageSubject ,@MessageBody ,@MessageIsRead );


END

OUTPUT子句應列列表之后:

insert into Messages (ParentID ,MessageFrom ,MessageSubject ,MessageBody ,MessageIsRead )
output INSERTED.ID INTO @message_id (MessageID)
values(@ParentID ,@MessageFrom ,@MessageSubject ,@MessageBody ,@MessageIsRead );

請參閱INSERT文檔。

(而且,顯然,您現在實際上需要對@message_id的內容進行實際操作 ,但是我想您尚未編寫或未在問題中顯示存儲過程的其余部分)

暫無
暫無

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

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