这个问题已经解决,但现在我想直接更新
我有一张像这样的桌子
id | cod | type | qta
-: | :-- | :---------- | --:
1 | aaa | aaa,bbb,ccc | 3
2 | aaa | ddd | 1
3 | aaa | eee,fff | 4
4 | aaa | ggg,hhh | 2
5 | aaa | iii | 7
6 | aaa | lll | 7
我想要一个像这样的结果
id | cod | type | qta
-: | :-- | :---------- | --:
1 | aaa | aaa_1,bbb_1,ccc_1 | 3
2 | aaa | ddd_1 | 1
3 | aaa | eee,fff | 4
4 | aaa | ggg_1,hhh_1 | 2
5 | aaa | iii | 7
6 | aaa | lll | 7
我想更新字符串中的每个单词,其中字符串中的单词数与"qta"相同。
为了获得行,我使用
select *
from tab1
where char_length(type) - char_length(replace(type, ',', '')) + 1 = qta
但我想要:
update tab1
SET type = ...
where char_length(type) - char_length(replace(type, ',', '')) + 1 = qta;
这里的链接使测试
您可以尝试以下内容,
UPDATE tab1
JOIN
(SELECT
id, CONCAT(REPLACE(type, ',', '_1,'), '_1') AS type
FROM
tab1
WHERE
CHAR_LENGTH(type) - CHAR_LENGTH(REPLACE(type, ',', '')) + 1 = qta) val ON tab1.id = val.id
SET
tab1.type = val.type;