gpt4 book ai didi

mysql - 如何在mysql中使用存储过程将记录从一个表保存到另一个表?

转载 作者:太空宇宙 更新时间:2023-11-03 12:35:57 25 4
gpt4 key购买 nike

我试过了,但我不知道该怎么做。我想使用存储过程将记录从一个表迁移到另一个表。我从一个简单的程序(不确定是对是错)开始,根据某些条件打印记录。这是我尝试过的代码:

CREATE PROCEDURE curdemo()
BEGIN
DECLARE done INT DEFAULT FALSE;
DECLARE a VARCHARCHAR(16);
DECLARE cur1 CURSOR FOR SELECT user_name FROM discovery_configuration;
OPEN cur1;
REPEAT
FETCH cur1 INTO a;
IF a!=' ' THEN
select a;
END IF;
END REPEAT;
CLOSE cur1;
END;

如果 user_name 列为空,我需要一个存储过程将这些记录迁移到另一个表。谁能指导我?

最佳答案

为什么一定要是存储过程?

您可以在一个查询中复制记录,然后用另一个查询删除它们。

复制到另一个user_name为空的表:

INSERT INTO other_table (id, user_name, other)
SELECT (id, user_name, other)
FROM discovery_configuration
WHERE user_name IS NULL OR TRIM(user_name) = '';

然后,复制这些记录后,从原始表中删除:

DELETE FROM discovery_configuration WHERE id IN (SELECT id FROM other_table);

关于mysql - 如何在mysql中使用存储过程将记录从一个表保存到另一个表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13184871/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com