Для прикладу циклу в MySQL


104

У MySQL у мене є ця збережена процедура з циклом For у ній:

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 $$

Він завжди друкує 1. Який правильний синтаксис для циклу MySQL for?


Це створює назви процедур зберігання ABC. Який формат даних (який ви хочете завантажити) ?.
Зімбабао

я не хочу будь-якого формату даних, я просто хочу надрукувати значення від 1 до 5
Chitresh

Я просто спробував цей код, і він працював на мене. Мені довелося додати CALL ABC (); але це спрацювало Я також додав DROP PROCEDURE ABC () наприкінці, тому що я запускав його лише як тест.
Алан Стюарт

Відповіді:


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;

Дякую за вашу відповідь, мені це допомогло. Чи не могли б ви бути так люб'язні і побачити моє запитання stackoverflow.com/questions/12259675 / ... . Моє головне питання: чи потрібно використовувати BEGIN...ENDта створювати процедуру, якщо я хочу лише використовувати LOOP?
Зелений

1
Якщо у вас виникли проблеми з роздільниками, прочитати stackoverflow.com/a/10259528/632951
Pacerier

61

Приклад синтаксису циклу в 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//

Які відбитки:

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

Приклад синтаксису циклу REPEAT у 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//

Які відбитки:

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

Приклад синтаксису циклу для циклу в 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//

Які відбитки:

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

Зробіть підручник: http://www.mysqltutorial.org/stored-procedures-loop.aspx

Якщо я спіймаю вас, як випускаєте подібні конструкції для циклів MySQL у виробництво, я збираюсь стріляти вас у пінолетний ракет. Ви можете використовувати трубний гайковий ключ, щоб забити цвях, але це робить вас виглядати нерозумно.


2
Після вказаного вами коду введення declare str VARCHAR(255) default '';в консоль MySQL (5.6) дає мені повідомлення про помилку Error 1064 (42000): ... for the right syntax to use near '' at line 3, яке так само чітко, як і грязь (хоча я припускаю, що воно не любить пункт DEFAULT).
Agi Hammerthief

Раніше він працював у попередніх версіях. Я думаю, що це кінець розділового рядка для зміни: використовуйте команду delimiter //перед запуском цього.
Ерік Лещинський

Чи можемо ми користуватися Iterate і залишати в межах Хоча також? Вони діють у міру продовження та перерви. Чи схожі на Iterate твори, що продовжуються в Java?
Діпак

13

Припустимо, у вас є одна таблиця з назвою 'table1'. Він містить один стовпчик 'col1' з типом varchar. Нижче наведено запит до таблиці для ящиків

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

Тепер, якщо ви хочете вставити число від 1 до 50 в цю таблицю, використовуйте наступну збережену процедуру

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 $$

Для виклику використання збереженої процедури

CALL `ABC`()

1

Ви можете обміняти цю локальну змінну на глобальну, було б простіше.

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 $$
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.