Как отладить синтаксическую ошибку в моем коде курсора MySQL?

#mysql #cursor

#mysql #курсор

Вопрос:

У меня ошибка с этим кодом курсора:

 delimiter//
CREATE FUNCTION updateOrder()
DETERMINISTIC
BEGIN
DECLARE done INT DEFAULT 0;
# déclare les variables qui vont accueillir les données retournées par la requête
DECLARE i_id_produit INTEGER;
DECLARE old_id_produit INTEGER;
DECLARE cpt INTEGER;
# déclare le curseur
DECLARE ccustomers CURSOR FOR SELECT id_produit
FROM produit_documentation order by id_produit;
# déclare un handler pour détecter la fin du jeu d'enregistrements
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
# ouvre le curseur
OPEN ccustomers;
REPEAT
FETCH ccustomers INTO i_id_produit;
IF i_id_produit = old_customer_id THEN
UPDATE produit_documentation SET ordre = cpt;
cpt  ;
ELSE old_customer_id = i_id_produit;
END IF;
UNTIL done END REPEAT;
END
//
  

Я получаю эту ошибку:

 Script line: 2  You have an error in your SQL syntax; check the manual that
corresponds to your MySQL server version for the right syntax to use near 
'DETERMINISTIC
BEGIN
DECLARE done INT DEFAULT 0;
# déclare les variables qui ' at line 2
  

Я использую MySQL 5.5.

Ответ №1:

Вам нужно RETURNS предложение после вашего CREATE FUNCTION , вот так:

 DELIMITER //
CREATE FUNCTION updateOrder() RETURNS varchar(255)
DETERMINISTIC
...
  

Смотрите это для деталей.

Не забудьте добавить соответствующий RETURN оператор и вернуть свой разделитель на ; в конце. 🙂

ETA: Или сделайте это PROCEDURE вместо, как в этом примере.