>  기사  >  데이터 베이스  >  mysql에는 for 루프가 있나요?

mysql에는 for 루프가 있나요?

青灯夜游
青灯夜游원래의
2023-03-30 20:26:316586검색

mysql에는 for 루프가 없습니다. MySQL은 for 루프 문을 지원하지 않습니다. WHILE, REPEAT 및 LOOP의 세 가지 루프 문을 지원합니다. WHILE 루프는 각 반복이 시작될 때 표현식을 확인합니다. 사후 테스트 루프라고도 하는 REPEAT 루프 문은 문을 실행한 후 표현식을 확인하여 코드 블록을 반복적으로 실행할 수 있습니다.

mysql에는 for 루프가 있나요?

이 튜토리얼의 운영 환경: windows10 시스템, mysql 버전 8.0, Dell G3 컴퓨터.

mysql의 루프 문

MySQL은 조건에 따라 SQL 코드 블록을 반복적으로 실행할 수 있는 루프 문을 제공합니다.

MySQL은 루프 문을 지원하지 않습니다. MySQL은 while 루프, 반복 루프 및 루프 루프만 지원합니다.

MySQL은 조건에 따라 SQL 코드 블록을 반복적으로 실행할 수 있는 루프 문을 제공합니다. MySQL은 for 루프 문을 지원하지 않습니다. MySQL에는 WHILE, REPEATLOOP의 세 가지 루프 문이 있습니다.
WHILEREPEATLOOP

我们将在以下部分中更详细地检查每个循环语句。

WHILE循环

WHILE语句的语法如下:

WHILE expression DO
   statements
END WHILE

WHILE循环在每次迭代开始时检查表达式。 如果expressionevaluatesTRUE,MySQL将执行WHILEEND WHILE之间的语句,直到expressionevaluatesFALSEWHILE循环称为预先测试条件循环,因为它总是在执行前检查语句的表达式。

下面的流程图说明了WHILE循环语句:

mysql에는 for 루프가 있나요?

以下是在存储过程中使用WHILE循环语句的示例:

DELIMITER $$
 DROP PROCEDURE IF EXISTS test_mysql_while_loop$$
 CREATE PROCEDURE test_mysql_while_loop()
 BEGIN
 DECLARE x  INT;
 DECLARE str  VARCHAR(255);

 SET x = 1;
 SET str =  '';

 WHILE x  <p>在上面的<code>test_mysql_while_loop</code>存储过程中:</p>
  • 首先,重复构建str字符串,直到x变量的值大于5
  • 然后,使用SELECT语句显示最终的字符串。

要注意,如果不初始化x变量的值,那么它默认值为NULL。 因此,WHILE循环语句中的条件始终为TRUE,并且您将有一个不确定的循环,这是不可预料的。

下面来测试test_mysql_while_loopstored调用存储过程:

CALL test_mysql_while_loop();

执行上面查询语句,得到以下结果 -

mysql> CALL test_mysql_while_loop();
+------------+
| str        |
+------------+
| 1,2,3,4,5, |
+------------+
1 row in set

Query OK, 0 rows affected

REPEAT循环

REPEAT循环语句的语法如下:

REPEAT
 statements;
UNTIL expression
END REPEAT

首先,MySQL执行语句,然后评估求值表达式(expression)。如果表达式(expression)的计算结果为FALSE,则MySQL将重复执行该语句,直到该表达式计算结果为TRUE

因为REPEAT循环语句在执行语句后检查表达式(expression),因此REPEAT循环语句也称为测试后循环。

下面的流程图说明了REPEAT循环语句的执行过程:

mysql에는 for 루프가 있나요?

我们可以使用REPEAT循环语句重写test_mysql_while_loop存储过程,使用WHILE循环语句:

DELIMITER $$
 DROP PROCEDURE IF EXISTS mysql_test_repeat_loop$$
 CREATE PROCEDURE mysql_test_repeat_loop()
 BEGIN
 DECLARE x INT;
 DECLARE str VARCHAR(255);

 SET x = 1;
        SET str =  '';

 REPEAT
 SET  str = CONCAT(str,x,',');
 SET  x = x + 1; 
        UNTIL x  > 5
        END REPEAT;

        SELECT str;
 END$$
DELIMITER ;

要注意的是UNTIL表达式中没有分号(;)。

执行上面查询语句,得到以下结果 -

mysql> CALL mysql_test_repeat_loop();
+------------+
| str        |
+------------+
| 1,2,3,4,5, |
+------------+
1 row in set

Query OK, 0 rows affected

LOOP,LEAVE和ITERATE语句

有两个语句允许您用于控制循环:

  • LEAVE语句用于立即退出循环,而无需等待检查条件。LEAVE语句的工作原理就类似PHP,C/C++,Java等其他语言的break语句一样。
  • ITERATE语句允许您跳过剩下的整个代码并开始新的迭代。ITERATE语句类似于PHPC/C++Java等中的continue语句。

MySQL还有一个LOOP语句,它可以反复执行一个代码块,另外还有一个使用循环标签的灵活性。

以下是使用LOOP

다음 섹션에서 각 루프 문을 더 자세히 살펴보겠습니다. 🎜🎜🎜WHILE loop🎜🎜🎜🎜WHILE 문의 구문은 다음과 같습니다: 🎜
CREATE PROCEDURE test_mysql_loop()
 BEGIN
 DECLARE x  INT;
        DECLARE str  VARCHAR(255);

 SET x = 1;
        SET str =  '';

 loop_label:  LOOP
 IF  x > 10 THEN 
 LEAVE  loop_label;
 END  IF;

 SET  x = x + 1;
 IF (x mod 2) THEN
     ITERATE  loop_label;
 ELSE
    SET  str = CONCAT(str,x,',');
 END IF;
    END LOOP;    
    SELECT str;
END;
🎜WHILE 매번 반복됩니다. 반복 시작 시 표현식이 확인됩니다. expressionevaluatesTRUE이면 MySQL은 expressionevaluates가 될 때까지 WHILEEND WHILE 사이의 명령문을 실행합니다. 코드>는 FALSE입니다. WHILE 루프는 항상 문의 표현식을 실행하기 전에 확인하기 때문에 사전 테스트 조건 루프라고 합니다. 🎜🎜다음 순서도는 WHILE 루프 문을 보여줍니다. 🎜🎜mysql에는 for 루프가 있나요?🎜🎜다음은 저장 프로시저에서 WHILE 루프 문을 사용하는 예입니다. 🎜
mysql> CALL test_mysql_loop();
+-------------+
| str         |
+-------------+
| 2,4,6,8,10, |
+-------------+
1 row in set

Query OK, 0 rows affected
🎜위 에서 test_mysql_while_loop code>저장 프로시저에서: 🎜<ul> <li>먼저 <code>x 변수의 값이 보다 클 때까지 <code>str 문자열을 반복적으로 빌드합니다. 5.
  • 그런 다음 SELECT 문을 사용하여 최종 문자열을 표시합니다.
  • 🎜주의해야 할 점 x 변수의 값이 초기화되지 않은 경우 기본값은 NULL입니다. >. 따라서 WHILE 루프 문의 조건은 항상 TRUE이며 예측할 수 없는 불확실한 루프가 발생하게 됩니다. 🎜🎜 test_mysql_while_loopstored를 테스트하여 저장 프로시저를 호출해 보겠습니다. 🎜rrreee🎜위 쿼리 문을 실행하고 다음 결과를 얻습니다. -🎜rrreee🎜🎜REPEAT loop🎜🎜 🎜🎜REPEAT 루프 문의 구문은 다음과 같습니다. 🎜rrreee🎜먼저 MySQL은 해당 문을 실행한 다음 평가 식(expression)을 평가합니다. 표현식(expression)이 FALSE로 평가되면 MySQL은 표현식이 TRUE로 평가될 때까지 명령문을 반복적으로 실행합니다. 🎜🎜REPEAT 루프문은 명령문을 실행한 후 표현식(expression)을 확인하기 때문에 REPEAT 루프문을 사후 테스트라고도 합니다. 고리. 🎜🎜다음 순서도는 REPEAT 루프 문의 실행 프로세스를 보여줍니다. 🎜🎜mysql에는 for 루프가 있나요?🎜🎜 REPEAT 루프 문을 사용하여 test_mysql_while_loop 저장 프로시저를 다시 작성할 수 있습니다. WHILE 루프 문 사용: 🎜rrreee🎜UNTIL 표현식에는 세미콜론(;)이 없다는 점에 유의해야 합니다. 🎜🎜위의 쿼리 문을 실행하고 다음 결과를 얻습니다.🎜rrreee🎜🎜LOOP, LEAVE 및 ITERATE 문🎜🎜🎜🎜 loop: 🎜
    • LEAVE 문은 조건 확인을 기다리지 않고 즉시 루프를 종료하는 데 사용됩니다. LEAVE 문의 작동 원리는 PHP, C/C++, Java 및 기타 언어의 break 문과 유사합니다.
    • ITERATE 문을 사용하면 나머지 코드 전체를 건너뛰고 새 반복을 시작할 수 있습니다. ITERATE 문은 PHP, C/C++, Javacontinue와 유사합니다. , 등의 진술.
    🎜MySQL에는 코드 블록을 반복적으로 실행할 수 있는 LOOP 문도 있으며 루프 태그를 사용할 수 있는 유연성도 있습니다. 🎜🎜다음은 LOOP 루프문을 사용한 예입니다. 🎜
    CREATE PROCEDURE test_mysql_loop()
     BEGIN
     DECLARE x  INT;
            DECLARE str  VARCHAR(255);
    
     SET x = 1;
            SET str =  '';
    
     loop_label:  LOOP
     IF  x > 10 THEN 
     LEAVE  loop_label;
     END  IF;
    
     SET  x = x + 1;
     IF (x mod 2) THEN
         ITERATE  loop_label;
     ELSE
        SET  str = CONCAT(str,x,',');
     END IF;
        END LOOP;    
        SELECT str;
    END;
    • 以上存储过程仅构造具有偶数字符串的字符串,例如2,4,6等。
    • LOOP语句之前放置一个loop_label循环标签。
    • 如果x的值大于10,则由于LEAVE语句,循环被终止。
    • 如果x的值是一个奇数,ITERATE语句忽略它下面的所有内容,并开始一个新的迭代。
    • 如果x的值是偶数,则ELSE语句中的块将使用偶数构建字符串。

    执行上面查询语句,得到以下结果 -

    mysql> CALL test_mysql_loop();
    +-------------+
    | str         |
    +-------------+
    | 2,4,6,8,10, |
    +-------------+
    1 row in set
    
    Query OK, 0 rows affected

    【相关推荐:mysql视频教程

    위 내용은 mysql에는 for 루프가 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    성명:
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.