Как обновить две таблицы одновременно, используя одну хранимую процедуру? - PullRequest
1 голос
/ 01 марта 2012

У меня есть две таблицы в моей базе данных Requests и Balance трекер, который не имеет отношения .... но я хочу выбрать данные из двух таблиц и связать их с двумя сетками ...

Запросы

EmpID | EmpRqsts | EmpDescription | ApproverID | ApprovedAmount | RequestPriority
   1  | asdfsb   | sadbfsbdf      |     1      |
   2  | asbfd    | sjkfbsd        |     1      |

Отслеживание баланса

EmpId | BalanceAmnt | LastUpdated | lastApprovedAmount
  1   |    5000     | sdfbk       |
  2   |    3000     | sjbfsh      |

Теперь я хочу обновить обе таблицы одновременно, основываясь на EmpID. Всякий раз, когда сумма утверждается, она должна обновляться в request столбце таблицы [ApprovedAmount] и иметь приоритет ...

При обновлении [ApprovedAmount] [BalanceAmnt] также необходимо обновить отслеживание баланса, добавив утвержденную сумму, [LastUpdated], [lastApprovedAmount] следует обновить с указанием даты и времени

Может кто-нибудь помочь мне с вопросом, пожалуйста ....

Ответы [ 2 ]

0 голосов
/ 01 марта 2012

Пожалуйста, попробуйте это также без триггера

    CREATE procedure SP_UpdateRequestedAmount
   (
   @EmpID int,
   @AmountApproved varchar (50),
   @RequestPriority varchar (50)
   )
   as
   begin

   --Declare a variable for know current ApprovedAmount (that is before updation)
   Declare @CurrentApprovedAmount AS INT

   --set current ApprovedAmount
   SET @AmountApproved =(SELECT ApprovedAmount FROM Requests WHERE EmpID=@EmpID)

   --check is @CurrentApprovedAmount differ from @AmountApproved
   IF (@CurrentApprovedAmount!=@AmountApproved)
        BEGIN
                --Here we need to update  Requests and BalanceTracker
        END
    ELSE
        BEGIN
            --only update Requests -- no change in AmountApproved
        END 

   go
0 голосов
/ 01 марта 2012

Сначала создайте хранимую процедуру для обновления вашего [ApprovedAmount] столбца

create procedure SP_UpdateRequestedAmount
    (@EmpID int,
     @AmountApproved varchar (50),
     @RequestPriority varchar (50))
as
begin
    Update Requests   
    set ApprovedAmount = @AmountApproved,
        Request_Priority = @RequestPriority 
    where
        Emp_ID = @EmpID
end

Затем используйте тригер для обновления другой таблицы, когда обновляется столбец [AmountApproved]

CREATE TRIGGER tr_ApprovedAmount_UPDATE 
ON Requests   
AFTER UPDATE 
AS 
    --Make sure Priority was changed 
    IF NOT UPDATE(ApprovedAmount) 
        RETURN 

    --Determine if Priority was changed to high 

    -- PUT your queries for Updatating other table 
     declare @Balance_LastUpdated date
     declare @ApprovedDate date

     UPDATE Balance Tracker
     SET Balance Tracker.Balance_BalanceAmount =  Balance Tracker.Balance_BalanceAmount +   PTS_Requests.Request_IsApproved,
         Balance_LastUpdated = @Balance_LastUpdated,
         Balance_LastApproval = @ApprovedDate
     FROM
         Balance Tracker 
     INNER JOIN
         Requests ON Balance Tracker.Emp_ID = Requests.Emp_ID

Надеюсь, это поможет .........

...