我想在mysql中创建存储过程,我想在BIGINT中传递两个参数startDate,在INT中传递noOfDays。因此,在该存储过程中创建 TEMPORARY 表并在其中插入日期。例如,如果我通过了 8 月 1 日。和 10 然后在 TEMPORARY 表中的记录应该是从 8 月 1 日到 8 月 10 日。请为此提出建议。
问问题
971 次
1 回答
1
以下程序将为您执行此操作:
CREATE PROCEDURE sp_insert_date_data(arg_start_date DATE, arg_no_of_days INT unsigned)
BEGIN
SET @var_date_cnt = 0;
DROP TEMPORARY TABLE IF EXISTS tmp_date;
CREATE TEMPORARY TABLE tmp_date;
(
dates DATE NOT NULL
);
WHILE(@var_date_cnt < arg_no_of_days)
DO
INSERT INTO tmp_date(dates)
VALUES
(DATE_ADD(arg_start_date, INTERVAL @var_date_cnt DAY));
SET @var_date_cnt = @var_date_cnt + 1;
END WHILE;
SELECT * FROM tmp_date;
END;
于 2012-08-01T06:03:13.763 回答