Avatar billede Kaa85 Praktikant
03. februar 2012 - 19:46 Der er 1 kommentar og
1 løsning

Stored Procedure - Giv dit besyv.

Hej

Jeg var så "heldig" at jeg var i udlandet da vi havde om Stored Procedures i skolen, så dette er første gang jeg arbejder med det.

Jeg har kigget rundt omkring på nettet og har lavet min første SP, og den virker, men nu ku jeg så godt tænke mig at få lidt feedback på den. Here goes:


CREATE DEFINER=`root`@`localhost` PROCEDURE `upgradeUser`(IN userid int, IN duration_days int)
BEGIN
    DECLARE upgrades_before int;
    SELECT count(id) FROM upgrades INTO upgrades_before;

    START TRANSACTION;
           
    UPDATE module_user SET superuser = '1' WHERE id = userid;
    INSERT INTO upgrades (user, duration) VALUES (userid, duration_days);
   
    IF (SELECT count(id) FROM upgrades) > upgrades_before AND (SELECT superuser FROM module_user WHERE id = userid) = '1' THEN
        COMMIT;
    ELSE
        ROLLBACK; 
    END IF; 
    SELECT superuser FROM module_user WHERE id = userid;
END


Den er meget simpel, men alligevel vil jeg gerne høre din mening. Specielt til sidst hvor jeg laver et commit eller et rollback, er mit "check" (IF / ELSE) den rigtige måde at gøre det på?

For mig virker det lidt "dumt" at tjekke ved at lave SELECT og COUNT, men jeg kan ikke rigtig se andre måder at tjekke om daten er indsat / opdateret.
Avatar billede Kaa85 Praktikant
03. februar 2012 - 19:49 #1
Hov linjen mellem END IF og END var en test, og er egentligt ikke med i det endelig resultat.
Avatar billede Kaa85 Praktikant
18. februar 2012 - 07:48 #2
svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Computerworld tilbyder specialiserede kurser i database-management

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester