0
我是新來的存儲過程,並管理谷歌,創建一個存儲過程插入或更新數據庫。從Oracle數據庫中選擇一組記錄,並根據使用BizTalk將它更新或更新到Sql數據庫表中的em_id 嘗試創建存儲過程以根據字段插入或更新記錄。存儲過程更新或插入
CREATE PROCEDURE [dbo].[usp_InsertorUpdateDB]
@dp_id char(32),
@dv_id char(32),
@em_number char(12),
@email varchar(50),
@emergency_relation char(32),
@option1 char(16),
@status char(20),
@em_id char(35),
@em_title varchar(64),
@date_hired datetime
AS
MERGE [dbo].[em] AS [Target]
USING (SELECT @dp_id, @dv_id , @em_number, @email, @emergency_relation, @option1, @status, @em_id, @em_title, @date_hired)
AS [Source] ([dp_id], [dv_id], [em_number], [email], [emergency_relation], [option1], [status], [em_id], [em_title], [date_hired])
ON [Target].[em_id] = [Source].[em_id]
WHEN MATCHED THEN
UPDATE SET [dp_id] = [Source].[dp_id],
[dv_id] = [Source].[dv_id],
[em_number] = [Source].[em_number],
[email] = [Source].[email],
[emergency_relation] = [Source].[emergency_relation],
[option1] = [Source].[option1],
[status] = [Source].[status],
[em_id] = [Source].[em_id],
[em_title] = [Source].[em_title],
[date_hired] = [Source].[date_hired]
WHEN NOT MATCHED THEN
INSERT ([dp_id], [dv_id], [em_number], [email], [emergency_relation], [option1], [status], [em_id], [em_title],[date_hired])
VALUES ([Source].[dp_id], [Source].[dv_id], [Source].[em_number], [Source].[email], [Source].[emergency_relation], [Source].[option1], [Source].[status], [Source].[em_id], [Source].[em_title], [Source].[date_hired]);
GO
我問一個問題前兩天,因爲它顯示了關鍵字「何時」近
不正確的語法。
有一個評論顯示代碼很容易出現死鎖。由於我是新的存儲過程,我不知道如何創建存儲過程插入或更新沒有死鎖。我真的卡住了。
是在合併可能容易出現死鎖。您需要使用傳統版本。首先你做一個更新。如果@@ ROWCOUNT = 0,則執行插入操作。 –
我從Oracle數據庫中選擇記錄並使用BizTalk將其插入到Sql數據庫表中。 @@ ROWCOUNT在這裏工作嗎? – xyz
是的。 Rowcount只是返回最後一條語句影響的行數。 –