Chcę sprawdzić tabelę PREMIUM_SERVICE_USER
jeśli wszelkie rekordy istnieje strClientID
aktualizacji timeValid
do +30 jeśli ma zapisów do strClientID
Włożyć do premium_service_user
tabeli.Sprawdź, czy rekord istnieje, jeżeli tak „update” jeśli nie „wstawić”
Co robię źle?
Zwiększa się o timeValid
przez +30 dni, ale wstawia też inny wiersz.
SELECT @pre_var = count(*)
FROM PREMIUM_SERVICE_USER
WHERE strClientID = @strClientID
/* bronze premium - 200 cash */
IF @Premium = 1
BEGIN
INSERT INTO PREMIUM_SERVICE_USER
(strClientID, timeReg, timeValid, bCurrent, durum)
VALUES
(@strClientID,getdate(),getdate() + 30,'1','1')
UPDATE TB_USER
SET cash = cash+200
WHERE strAccountID = @strClientID
END
IF @Premium = 1 AND @pre_var = 1
BEGIN
UPDATE PREMIUM_SERVICE_USER
SET timevalid = timevalid+30 where strClientID = @strClientID
UPDATE PREMIUM_SERVICE_USER
SET bCurrent = 1 where strClientID = @strClientID
UPDATE TB_USER
SET cash = cash+200 WHERE strAccountID = @strClientID
END
Oprócz poprawki znaleźć poniżej Chciałbym również zasugerować, że można połączyć sprawozdania Update w jednej instrukcji dla PREMIUM_SERVICE_USER –