-- 假设有一个名为 `orders` 的表,其中包含一个名为 `order_id` 的字段,
-- 我们需要将 `order_id` 字段按照指定的分隔符拆分成多条记录。
-- 创建一个存储过程,用于将单个记录中的字符串字段拆分为多条记录
DELIMITER $$
CREATE PROCEDURE `split_order_id`(IN input_order_id INT)
BEGIN
DECLARE finished INTEGER DEFAULT 0;
DECLARE order_id INT;
DECLARE order_id_cursor CURSOR FOR
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(input_order_id, ',', numbers.n), ',', -1) order_id
FROM (
SELECT 1 n UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4
) numbers
WHERE n <= (LENGTH(input_order_id) - LENGTH(REPLACE(input_order_id, ',', '')) + 1);
DECLARE CONTINUE HANDLER FOR NOT FOUND SET finished = 1;
OPEN order_id_cursor;
read_loop: LOOP
FETCH order_id_cursor INTO order_id;
IF finished = 1 THEN
LEAVE read_loop;
END IF;
-- 这里可以插入新记录到目标表,例如 `orders`
INSERT INTO orders (order_id) VALUES (order_id);
END LOOP;
CLOSE order_id_cursor;
END$$
DELIMITER ;
-- 调用存储过程,传入需要拆分的 `order_id` 值
CALL split_order_id('123,456,789');
这个存储过程会将传入的 order_id
字符串按照逗号分隔符拆分,并为每个分割后的子字符串创建一个新的记录。这个例子展示了如何使用MySQL存储过程和游标来处理字符串的拆分,并根据需要进行进一步的操作。