共用方式為


WHILE 語句

適用於:已勾選為是 Databricks SQL 已勾選為是 Databricks Runtime 16.3 和以上版本

當條件為 true 時,重複語句清單的執行。

這個語句只能在複合語句 中使用,

語法

[ label : ] WHILE cond DO
  { stmt ; } [...]
  END WHILE [ label ]

參數

  • 標籤

    迴圈的選擇性標籤,在包含 WHILE 語句的所有語句標籤中是唯一的。 標籤可用於 離開重複 迴圈。

  • cond

    評估結果為 BOOLEAN 的任何表達式

  • stmt

    SQL 語句

例子

-- sum up all odd numbers from 1 through 10
> BEGIN
    DECLARE sum INT DEFAULT 0;
    DECLARE num INT DEFAULT 0;
    sumNumbers: WHILE num < 10 DO
      SET num = num + 1;
      IF num % 2 = 0 THEN
        ITERATE sumNumbers;
      END IF;
      SET sum = sum + num;
    END WHILE sumNumbers;
    VALUES (sum);
  END;
 25

-- Compare with the much more efficient relational computation:
> SELECT sum(num) FROM range(1, 10) AS t(num) WHERE num % 2 = 1;
 25