MySQL WHILE循环

时间:2019-11-20 08:52:33  来源:igfitidea点击:

简介:在本教程中,您将学习如何使用MySQL WHILE循环语句重复执行一个或多个语句,只要条件为真。

MySQL WHILE循环语句简介

WHILE循环是一个循环语句,只要条件为真,它就会重复执行代码块。

这是WHILE语句的基本语法:

[begin_label:] WHILE search_condition DO
    statement_list
END WHILE [end_label]

使用以下语法:

首先,在WHILE关键字之后指定搜索条件。

WHILE在每次迭代开始时检查search_condition。

如果search_condition的值为TRUE,则只要search_condition为TRUE,WHILE就会执行statement_list。

WHILE循环称为预测试循环,因为它在statement_list执行之前检查search_condition。

其次,指定一个或多个将在DO和END WHILE关键字之间执行的语句。

第三,在循环结构的开头和结尾为WHILE语句指定可选标签。

以下流程图说明了MySQL WHILE循环语句:

MySQL WHILE循环语句示例

首先,创建一个名为calendars的表,该表存储日期和派生的日期信息,例如日,月,季度和年:

CREATE TABLE calendars(
    id INT AUTO_INCREMENT,
    fulldate DATE UNIQUE,
    day TINYINT NOT NULL,
    month TINYINT NOT NULL,
    quarter TINYINT NOT NULL,
    year INT NOT NULL,
    PRIMARY KEY(id)
);

其次,创建一个新的存储过程以在日历表中插入一个日期:

DELIMITER $$

CREATE PROCEDURE InsertCalendar(dt DATE)
BEGIN
    INSERT INTO calendars(
        fulldate,
        day,
        month,
        quarter,
        year
    )
    VALUES(
        dt, 
        EXTRACT(DAY FROM dt),
        EXTRACT(MONTH FROM dt),
        EXTRACT(QUARTER FROM dt),
        EXTRACT(YEAR FROM dt)
    );
END$$

DELIMITER ;

第三,创建一个新的存储过程LoadCalendars(),它将从开始日期开始的天数加载到日历表中。

DELIMITER $$

CREATE PROCEDURE LoadCalendars(
    startDate DATE, 
    day INT
)
BEGIN
    
    DECLARE counter INT DEFAULT 1;
    DECLARE dt DATE DEFAULT startDate;

    WHILE counter <= day DO
        CALL InsertCalendar(dt);
        SET counter = counter + 1;
        SET dt = DATE_ADD(dt,INTERVAL 1 day);
    END WHILE;

END$$

DELIMITER ;

存储过程LoadCalendars()接受两个参数:

  • startDate是插入日历表中的开始日期。

  • day是从startDate开始加载的天数。

在LoadCalendars()存储过程中:

首先,声明一个计数器和dt变量以保留立即值。
counter和dt的默认值分别为1和startDate。

然后,检查计数器是否少于或等于一天,如果是:

  • 调用存储过程InsertCalendar()将行插入日历表。

  • 将计数器增加一。
    另外,使用DATE_ADD()函数将dt增加一天。

WHILE循环将日期重复插入日历表中,直到计数器等于天。

以下语句调用存储过程LoadCalendars()从2019年1月1日开始将31天加载到日历表中。

CALL LoadCalendars('2019-01-01',31);

在本教程中,您学习了如何使用MySQL WHILE循环来重复执行一个或多个语句,只要条件为真。