gpt4 book ai didi

MySQL 过程 : error in fetch

转载 作者:行者123 更新时间:2023-11-29 18:27:22 24 4
gpt4 key购买 nike

我遇到了这个问题。我使用的是 MySQL 5.7.10

我已经定义了这个 PL(我知道,TRAZAS 表中的调试消息有点杂乱):

DROP procedure IF EXISTS my_proc;
DELIMITER $
CREATE PROCEDURE my_proc(... , OUT resultado INT, OUT mensaje TEXT)
MODIFIES SQL DATA
BEGIN

DECLARE sqlstate_code VARCHAR(10);
DECLARE message_text TEXT;
DECLARE mysql_errno INT;

DECLARE v_id_cliente VARCHAR(100) DEFAULT '';
DECLARE v_device VARCHAR(100) DEFAULT '';
DECLARE v_fecha_solicitud_crm DATETIME;
DECLARE v_id_ciclo VARCHAR(50);
DECLARE v_fecha_alta DATETIME;
DECLARE v_fecha_baja DATETIME;
DECLARE v_fecha_alta_promocion DATETIME;


DECLARE done INT DEFAULT FALSE;


DECLARE my_cursor CURSOR FOR
select id_cliente, device, fecha_solicitud_crm, id_ciclo,
min(FECHAS.fecha_inicio) AS FECHA_INICIO, max(FECHAS.fecha_fin) AS FECHA_FIN
from xxx
where
xxx
GROUP BY xxx
ORDER BY xxx;


DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;

DECLARE EXIT HANDLER FOR SQLEXCEPTION
BEGIN
ROLLBACK;
SET resultado = 1;

START TRANSACTION;
INSERT INTO TRAZAS(TEXTO) VALUES (concat_ws(' - ', 'ERROR my_proc'));
COMMIT;

get diagnostics condition 1 message_text = MESSAGE_TEXT, sqlstate_code = RETURNED_SQLSTATE, mysql_errno = MYSQL_ERRNO;
SET mensaje = concat_ws(' - ', sqlstate_code, mysql_errno, message_text);

START TRANSACTION;
INSERT INTO TRAZAS(TEXTO) VALUES (concat_ws(' - ', 'ERROR my_proc', mensaje));
COMMIT;

END;

SET resultado = 0;
SET mensaje = '';




OPEN my_cursor;

/* Inicio del bucle */
read_loop: LOOP

START TRANSACTION;
INSERT INTO TRAZAS(TEXTO) VALUES ('Inicio del loop. Antes del fetch');
COMMIT;


FETCH my_cursor INTO v_id_cliente, v_device, v_fecha_solicitud_crm, v_id_ciclo, v_fecha_alta, v_fecha_baja;
IF done THEN
LEAVE read_loop;
END IF;


START TRANSACTION;
INSERT INTO TRAZAS(TEXTO) VALUES ('Despues del fetch');
COMMIT;


/*****/
START TRANSACTION;
INSERT INTO TRAZAS(TEXTO) VALUES (concat_ws(' - ', 'my_proc', 'v_id_cliente', v_id_cliente));
INSERT INTO TRAZAS(TEXTO) VALUES (concat_ws(' - ', 'my_proc', 'v_device', v_device));
INSERT INTO TRAZAS(TEXTO) VALUES (concat_ws(' - ', 'my_proc', 'v_fecha_solicitud_crm', v_fecha_solicitud_crm));
INSERT INTO TRAZAS(TEXTO) VALUES (concat_ws(' - ', 'my_proc', 'v_fecha_alta', v_fecha_alta));
INSERT INTO TRAZAS(TEXTO) VALUES (concat_ws(' - ', 'my_proc', 'v_fecha_baja', v_fecha_baja));
COMMIT;
/*****/


/*
Stuff with fetched data
*/


START TRANSACTION;
INSERT INTO TRAZAS(TEXTO) VALUES ('Siguiente iteracion del loop');
COMMIT;


/* Fin del bucle */
END LOOP read_loop;

CLOSE my_cursor;

END$
DELIMITER ;

我确信光标选择了 6 行。我在 HeidiSQL 中使用相同的 PL 输入数据运行该查询,它获取 6 行。

此外,我确信 6 行中的任何字段均为空或空白。所有数据均已满足。

不幸的是,游标仅返回 1 行。当前的行为是:

  • 第一行已获取并处理。事情做对了。 First row image
  • 第二行仅显示“Inicio del循环”。 Antes del fetch' 消息。未显示第二条消息(“Despues del fetch”)。

Second row image

  • 使用 select @resultado, @mensaje 检索结果并退出消息时,显示 0 和空白。

Zero resultado

所以,似乎原生 FETCH 语句中有错误,但我无法通过“获取诊断”获得有关该错误的任何信息,HeidiSQL 没有显示任何内容...

我被困在这一点上。非常感谢任何帮助。

更新1:以下是HeidiSQL中游标查询检索到的实际数据:

INSERT INTO `myTable` (`id_cliente`, `device`, `fecha_solicitud_crm`, `id_ciclo`, `FECHA_INICIO`, `FECHA_FIN`) VALUES ('cod1-6a00-43b6-86ad-1234567e551', '60601234567533098', '2017-08-17', 'C14', '2017-07-02 05:00:22', '2017-07-21 05:55:03');
INSERT INTO `myTable` (`id_cliente`, `device`, `fecha_solicitud_crm`, `id_ciclo`, `FECHA_INICIO`, `FECHA_FIN`) VALUES ('cod2-25d3-4282-a471-12345672806', '60601234567516069', '2017-08-17', 'C14', '2017-02-19 07:03:47', '2017-07-19 07:55:02');
INSERT INTO `myTable` (`id_cliente`, `device`, `fecha_solicitud_crm`, `id_ciclo`, `FECHA_INICIO`, `FECHA_FIN`) VALUES ('cod3-c07d-42cd-9b23-12345671c2e', '60601234567605474', '2017-08-17', 'C14', '2017-06-29 05:40:17', '2017-07-27 05:05:02');
INSERT INTO `myTable` (`id_cliente`, `device`, `fecha_solicitud_crm`, `id_ciclo`, `FECHA_INICIO`, `FECHA_FIN`) VALUES ('cod4-aafe-4442-a429-12345679312', '60601234567543931', '2017-08-17', 'C14', '2017-06-24 05:22:24', '2017-07-19 07:55:02');
INSERT INTO `myTable` (`id_cliente`, `device`, `fecha_solicitud_crm`, `id_ciclo`, `FECHA_INICIO`, `FECHA_FIN`) VALUES ('cod5-0408-4656-84de-12345676ea5', '60601234567537024', '2017-08-17', 'C14', '2017-04-04 08:17:27', '2017-07-23 05:05:01');
INSERT INTO `myTable` (`id_cliente`, `device`, `fecha_solicitud_crm`, `id_ciclo`, `FECHA_INICIO`, `FECHA_FIN`) VALUES ('cod6-b1e2-4192-8f33-12345676ac1', '60601234567520152', '2017-08-17', 'C14', '2017-04-30 07:03:09', '2017-07-25 05:05:02');

最佳答案

我还没有修复我的 PL。

也许,里面有什么东西让光标不起作用,但我无法证明这一点。

所以,最后,我把它分成了两个 PL

  • 在第一个 PL 上,声明游标并检索所有行。
  • 然后,为每一行调用第二个 PL 并生成所有内容。

这种情况很少见,但现在可以了。

希望有帮助。谢谢。

关于MySQL 过程 : error in fetch,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46055513/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com