2017-02-24 2 views
-2

Quelqu'un peut-il me dire pourquoi cela ne fonctionne pasComment créer une table temporaire avec une requête select la mettre à jour et l'insérer dans mysql?

Create Procedure LeaveUpdate() 
Begin 
CREATE TEMPORARY TABLE leavebal AS (SELECT * FROM tbl_leave_balance WHERE month = month(DATE_SUB(now(), INTERVAL 1 MONTH)) and year = year(DATE_SUB(now(), INTERVAL 1 MONTH))); 
UPDATE leavebal SET leave_balance = 0 WHERE leave_balance < 0; 
UPDATE leavebal SET month = month(now()), year = year(now()), leaves_taken = 0, carry_forward = leave_balance, comp_off = 0; 
UPDATE leavebal SET total_leaves = carry_forward + leaves_allowed + comp_off, leave_balance = carry_forward + leaves_allowed + comp_off; 
INSERT INTO tbl_leave_balance (emp_id, month, year, carry_forward, leaves_allowed, comp_off, total_leaves, leaves_taken, leave_balance) 
SELECT emp_id, month, year, carry_forward, leaves_allowed, comp_off, total_leaves, leaves_taken, leave_balance FROM leavebal; 
End 
+1

Bienvenue sur Stack Overflow, malheureusement, votre question manque d'informations. Je vous suggère de lire [Comment puis-je poser une bonne question?] (Http://stackoverflow.com/help/how-to-ask) puis revenez et éditez votre question pour nous donner toutes les informations requises. Sans cela, nous ne pouvons pas vous aider et votre question risque d'être close. – Styphon

Répondre

0

Vous devez utiliser delimiter, essayez ceci:

DELIMITER $$ 

    DROP PROCEDURE IF EXISTS `LeaveUpdate` $$ 
Create Procedure LeaveUpdate() 
Begin 
CREATE TEMPORARY TABLE leavebal AS (SELECT * FROM tbl_leave_balance WHERE month = month(DATE_SUB(now(), INTERVAL 1 MONTH)) and year = year(DATE_SUB(now(), INTERVAL 1 MONTH))); 
UPDATE leavebal SET leave_balance = 0 WHERE leave_balance < 0; 
UPDATE leavebal SET month = month(now()), year = year(now()), leaves_taken = 0, carry_forward = leave_balance, comp_off = 0; 
UPDATE leavebal SET total_leaves = carry_forward + leaves_allowed + comp_off, leave_balance = carry_forward + leaves_allowed + comp_off; 
INSERT INTO tbl_leave_balance (emp_id, month, year, carry_forward, leaves_allowed, comp_off, total_leaves, leaves_taken, leave_balance) 
SELECT emp_id, month, year, carry_forward, leaves_allowed, comp_off, total_leaves, leaves_taken, leave_balance FROM leavebal; 
End$$ 

    DELIMITER ;