2015-04-06 107 views
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 

我問一個問題前兩天,因爲它顯示了關鍵字「何時」近

不正確的語法。

有一個評論顯示代碼很容易出現死鎖。由於我是新的存儲過程,我不知道如何創建存儲過程插入或更新沒有死鎖。我真的卡住了。

+0

是在合併可能容易出現死鎖。您需要使用傳統版本。首先你做一個更新。如果@@ ROWCOUNT = 0,則執行插入操作。 –

+0

我從Oracle數據庫中選擇記錄並使用BizTalk將其插入到Sql數據庫表中。 @@ ROWCOUNT在這裏工作嗎? – xyz

+0

是的。 Rowcount只是返回最後一條語句影響的行數。 –

回答

0

合併是死鎖的原因,你可以簡單地嘗試

 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 

    IF ((SELECT COUNT(em_id) FROM [dbo].[em] WHERE em_id = @em_id) > 0) 
     UPDATE [dbo].[em] 
     SET 
       [dp_id]     = @dp_id, 
       [dv_id]     = @dv_id, 
       [em_number]    = @em_number, 
       [email]     = @email, 
       [emergency_relation] = @emergency_relation, 
       [option1]    = @option1, 
       [status]    = @status, 
       [em_id]     = @em_id, 
       [em_title]    = @em_title, 
       [date_hired]   = @date_hired 
WHERE em_id = @em_id 

    ELSE 

    INSERT INTO [dbo].[em] (dp_id, dv_id, em_number, email, emergency_relation, option1, [status], em_id, em_title,date_hired) 
    VALUES (@dp_id, @dv_id, @em_number, @email, @emergency_relation, @option1, @status, @em_id, @em_title, @date_hired); 
    GO 
相關問題