gpt4 book ai didi

php - 如何使用 PHP 或仅使用 MySQL 在 MySQL 中重命名重复项

转载 作者:行者123 更新时间:2023-11-29 05:39:50 25 4
gpt4 key购买 nike

到目前为止,尝试使用该代码重命名 MySQL 数据库中的重复项,但这只会在名称末尾添加 1。所以如果我有

    UPDATE phpfox_photo n 
JOIN (SELECT title_url, MIN(photo_id) min_id FROM phpfox_photo GROUP BY title_url HAVING COUNT(*) > 1) d
ON n.title_url = d.title_url AND n.photo_id <> d.min_id
SET n.title_url = CONCAT(n.title_url, '1');


Anna
Anna
Anna

结果是

Anna
Anna1
Anna11

当我得到 200 Annas 结果是 Anna1111111111111111111111111111111111111111111....等

如何在以下公司重命名

Anna
Anna1
Anna2

最佳答案

如果我没有遗漏任何东西,您可以创建一个存储过程,使用游标迭代抛出您的行,如下所示:

DECLARE counter INT DEFAULT 0;
DECLARE num_rows INT DEFAULT 0;
DECLARE offset INT;
DECLARE title_urlvalue VARCHAR(50);
DECLARE no_more_rows BOOLEAN;
DECLARE ucur CURSOR FOR
SELECT
UPDATE phpfox_photo n
JOIN (SELECT title_url, MIN(photo_id) min_id
FROM phpfox_photo GROUP BY title_url HAVING COUNT(*) > 1) d
ON n.title_url = d.title_url AND n.photo_id <> d.min_id;
SET offset = 1;
SET no_more_rows = TRUE;
select FOUND_ROWS() into num_rows;
OPEN ucur;
uloop: LOOP
FETCH ucur
if counter >= num_rows then
no_more_rows = False;
endif
INTO title_urlvalue;
IF no_more_rows THEN
CLOSE ucur;
LEAVE uloop;
END IF;
update title_urlvalue = Concat(title_urlvalue,offset);
SET offset = offset + 1;
SET counter = counter + 1;
END LOOP uloop;
close ucur;

关于php - 如何使用 PHP 或仅使用 MySQL 在 MySQL 中重命名重复项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7621460/

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