簡體   English   中英

MySQL說:#1338-處理程序聲明后的游標聲明

[英]MySQL said: #1338 - Cursor declaration after handler declaration

我正在開發Web項目,並且從oracle數據庫遷移到mysql數據庫時遇到一些問題。 我想用以下代碼創建函數:

DROP FUNCTION IF EXISTS F_MANIFEST_GABUNG_SMR;

DELIMITER //

CREATE FUNCTION F_MANIFEST_GABUNG_SMR (input_val   varchar(4000))
  RETURNS VARCHAR(4000)
BEGIN
  DECLARE return_text  VARCHAR(10000)  DEFAULT  NULL;
DECLARE not_found INT DEFAULT 0;

DECLARE CONTINUE HANDLER FOR NOT FOUND SET not_found = 1; 
  DECLARE x CURSOR FOR SELECT DISTINCT IFNULL(SMR,'-') SMR FROM MANIFEST_EDI_SMR WHERE BL_NBR = input_val; OPEN x;
 FETCH x INTO;
 WHILE NOT_FOUND=0
 DO
    SET return_text = concat(ifnull(return_text, '') , ' ' , IFNULL(x.SMR, '')) ;
  FETCH  INTO;
  END WHILE;
  CLOSE ;
  IF char_length(return_text) > 85 THEN
       SET return_text = concat(ifnull(substr(return_text,1,85), '') , ' detail asp BL'); 
  END IF;
  RETURN return_text;
END;
//

DELIMITER ;

我正在使用phpmyadmin存儲例程的功能。 謝謝你的幫助 :)

錯誤消息不言自明:您已在處理程序后聲明了游標,需要更改順序:

DROP FUNCTION IF EXISTS F_MANIFEST_GABUNG_SMR;

DELIMITER //

CREATE FUNCTION F_MANIFEST_GABUNG_SMR (input_val   varchar(4000))
  RETURNS VARCHAR(4000)
BEGIN
  DECLARE return_text  VARCHAR(10000)  DEFAULT  NULL;
DECLARE not_found INT DEFAULT 0;

-- Declare cursor before handler
DECLARE x CURSOR FOR SELECT DISTINCT IFNULL(SMR,'-') SMR 
 FROM MANIFEST_EDI_SMR WHERE BL_NBR = input_val; OPEN x;

-- handler need to be after cursor
DECLARE CONTINUE HANDLER FOR NOT FOUND SET not_found = 1; 

 FETCH x INTO;
 WHILE NOT_FOUND=0
 DO
    SET return_text = concat(ifnull(return_text, '') , ' ' , IFNULL(x.SMR, '')) ;
  FETCH  INTO;
  END WHILE;
  CLOSE ;
  IF char_length(return_text) > 85 THEN
       SET return_text = concat(ifnull(substr(return_text,1,85), '') , ' detail asp BL'); 
  END IF;
  RETURN return_text;
END;
//

DELIMITER ;

可以在以下位置找到更多詳細信息: https : //dev.mysql.com/doc/refman/8.0/en/cursors.html

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM