Por exemplo de loop em MySQL

104

No MySQL, tenho este procedimento armazenado com um loop For nele:

DELIMITER $$  
CREATE PROCEDURE ABC()

   BEGIN
      DECLARE a INT Default 0 ;
      simple_loop: LOOP
         SET a=a+1;
         select a;
         IF a=5 THEN
            LEAVE simple_loop;
         END IF;
   END LOOP simple_loop;
END $$

Sempre imprime 1. Qual é a sintaxe correta para um loop for do MySQL?

Chitresh
fonte
Isso cria nomes de procedimentos de armazenamento ABC. Qual é o seu formato de dados (aquele que você deseja carregar)?
Zimbabao
não quero nenhum formato de dados, só quero imprimir um valor de 1 a 5
Chitresh
Eu apenas tentei este código e funcionou para mim. Tive que adicionar CALL ABC (); mas funcionou. Também adicionei DROP PROCEDURE ABC () no final porque estava apenas executando como um teste.
Alan Stewart

Respostas:

143
drop table if exists foo;
create table foo
(
id int unsigned not null auto_increment primary key,
val smallint unsigned not null default 0
)
engine=innodb;

drop procedure if exists load_foo_test_data;

delimiter #
create procedure load_foo_test_data()
begin

declare v_max int unsigned default 1000;
declare v_counter int unsigned default 0;

  truncate table foo;
  start transaction;
  while v_counter < v_max do
    insert into foo (val) values ( floor(0 + (rand() * 65535)) );
    set v_counter=v_counter+1;
  end while;
  commit;
end #

delimiter ;

call load_foo_test_data();

select * from foo order by id;
Jon Black
fonte
Obrigado pela sua resposta, me ajudou. Você poderia ter a gentileza de ver minha pergunta stackoverflow.com/questions/12259675/… . Minha principal dúvida é: é necessário usar BEGIN...ENDe criar um procedimento se eu só quiser usar LOOP?
Verde,
1
Se você estiver tendo problemas com delimitadores, leia stackoverflow.com/a/10259528/632951
Pacerier
61

Exemplo de sintaxe de loop while no MySQL:

delimiter //

CREATE procedure yourdatabase.while_example()
wholeblock:BEGIN
  declare str VARCHAR(255) default '';
  declare x INT default 0;
  SET x = 1;

  WHILE x <= 5 DO
    SET str = CONCAT(str,x,',');
    SET x = x + 1;
  END WHILE;

  select str;
END//

Quais impressões:

mysql> call while_example();
+------------+
| str        |
+------------+
| 1,2,3,4,5, |
+------------+

Exemplo de sintaxe de loop REPEAT no MySQL:

delimiter //

CREATE procedure yourdb.repeat_loop_example()
wholeblock:BEGIN
  DECLARE x INT;
  DECLARE str VARCHAR(255);
  SET x = 5;
  SET str = '';

  REPEAT
    SET str = CONCAT(str,x,',');
    SET x = x - 1;
    UNTIL x <= 0
  END REPEAT;

  SELECT str;
END//

Quais impressões:

mysql> call repeat_loop_example();
+------------+
| str        |
+------------+
| 5,4,3,2,1, |
+------------+

Exemplo de sintaxe de loop FOR no MySQL:

delimiter //

CREATE procedure yourdatabase.for_loop_example()
wholeblock:BEGIN
  DECLARE x INT;
  DECLARE str VARCHAR(255);
  SET x = -5;
  SET str = '';

  loop_label: LOOP
    IF x > 0 THEN
      LEAVE loop_label;
    END IF;
    SET str = CONCAT(str,x,',');
    SET x = x + 1;
    ITERATE loop_label;
  END LOOP;

  SELECT str;

END//

Quais impressões:

mysql> call for_loop_example();
+-------------------+
| str               |
+-------------------+
| -5,-4,-3,-2,-1,0, |
+-------------------+
1 row in set (0.00 sec)

Faça o tutorial: http://www.mysqltutorial.org/stored-procedures-loop.aspx

Se eu pegar você colocando esse tipo de construção de loop for do MySQL em produção, vou atirar em você com o lançador de mísseis de espuma. Você pode usar uma chave inglesa para bater em um prego, mas isso faz você parecer bobo.

Eric Leschinski
fonte
2
Seguindo o código que você forneceu, digitar declare str VARCHAR(255) default '';no console do MySQL (5.6) me dá a mensagem de erro Error 1064 (42000): ... for the right syntax to use near '' at line 3, que é clara como lama (embora eu assuma que não goste da cláusula DEFAULT).
Agi Hammerthief
Costumava funcionar em versões anteriores. Acho que é o delimitador de fim de linha para mudar: use o comando delimiter //antes de executar isso.
Eric Leschinski
Podemos usar Iterate e Leave no While também? Estes estão agindo como continue e break. Iterate funciona de maneira semelhante a continuar em java?
Deepak
13

Suponha que você tenha uma tabela com o nome 'tabela1'. Ele contém uma coluna 'col1' com o tipo varchar. A consulta à tabela da caixa é fornecida abaixo

CREATE TABLE `table1` (
    `col1` VARCHAR(50) NULL DEFAULT NULL
)

Agora, se você deseja inserir um número de 1 a 50 nessa tabela, use o seguinte procedimento armazenado

DELIMITER $$  
CREATE PROCEDURE ABC()

   BEGIN
      DECLARE a INT Default 1 ;
      simple_loop: LOOP         
         insert into table1 values(a);
         SET a=a+1;
         IF a=51 THEN
            LEAVE simple_loop;
         END IF;
   END LOOP simple_loop;
END $$

Para chamar esse procedimento armazenado, use

CALL `ABC`()
Fathah Rehman P
fonte
1

Você pode trocar essa variável local por uma global, seria mais fácil.

DROP PROCEDURE IF EXISTS ABC;
DELIMITER $$  
CREATE PROCEDURE ABC()

   BEGIN
      SET @a = 0;
      simple_loop: LOOP
         SET @a=@a+1;
         select @a;
         IF @a=5 THEN
            LEAVE simple_loop;
         END IF;
   END LOOP simple_loop;
END $$
Bruno henrique
fonte