Как отделить строку и восстановить ее

Разделив список строк и заменив тот же список новыми значениями в mysql У меня есть следующие данные в таблице table_1 table_1 (Сохраненная структура)

code        value
12_A        ["A","B","C","D"]  
12_B        ["E","F","G","H"]
12_3        ["I","J","K","L"]

Но каждый код имеет разные значения с различным описанием. как::

code    value     description
12_A    A         Apple
12_A    B         Ball
12_A    C         Cat
12_A    D         Dog
12_B    E         Eagle
12_B    F         Flag
.       .         .
.       .         . 
.       .         .

Мне нужно отделить список значений от table_1 и необходимо сохранить снова в той же таблице i.e table_1 (в этой структуре)::

code            value
12_A            ["Apple","Ball","Cat","Dog"]
12_B            ["Eagle","Flag",.......]
12_3            [......................] 

Ответ 1

Вы можете использовать GROUP_CONCAT():

UPDATE Table1 s
SET s.value = (SELECT t.code,CONCAT('["',
                           GROUP_CONCAT(t.description ORDER BY t.description SEPARATOR '","'),
                           ']') 
             FROM Table_With_val t
             WHERE t.code = s.code
               AND s.value LIKE CONCAT('%"',t.value,'"%'))

Вы не предоставили исчерпывающей информации, я предположил, что второй образец данных, который вы предоставили, представляет собой существующую таблицу, а таблица1 - это таблица, которую вы хотите обновить.

ПРИМЕЧАНИЕ.. Это структура плохой. это в наибольшей степени вызывало бы проблему в будущем, особенно когда это было необходимо для объединения. Я настоятельно рекомендую вам нормализовать ваши данные и хранить каждое описание и значение в своей собственной записи.

Ответ 2

вы можете создать функцию, в которой вы можете передать свой список строк в качестве параметра в случае вашего примера [ "A", "B", "C", "D" ] будет параметр. Функция будет разбивать строку и будет конкатенировать описания согласно. Пример функции, которую вы можете использовать, приведен ниже:

DELIMITER $$

DROP FUNCTION IF EXISTS codeToDesc$$

CREATE FUNCTION codeToDesc(commaSeperatedCodeList TEXT) RETURNS TEXT CHARSET utf8
BEGIN
DECLARE finalString TEXT;
DECLARE inputCodeList TEXT;
DECLARE codeName VARCHAR(255);
DECLARE codecount BIGINT(5);

SET finalString='';
SET inputCodeList = REPLACE(REPLACE(REPLACE(commaSeperatedCodeList,'[',''),']',''),'"','');

DROP TEMPORARY TABLE IF EXISTS test.code_table;
DROP TEMPORARY TABLE IF EXISTS test.code_count;
CREATE TEMPORARY TABLE test.code_table (CODE VARCHAR(255));
CREATE TEMPORARY TABLE test.code_count (countNo BIGINT(11));

INSERT INTO test.code_count(countNo) SELECT(LENGTH(inputCodeList)-LENGTH(REPLACE(inputCodeList,',','')) + 1);

BEGIN

    DECLARE table_cursor CURSOR FOR SELECT countNo FROM test.code_count;
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET codecount = (SELECT countNo FROM test.code_count ORDER BY countNo ASC LIMIT 1);

    OPEN table_cursor;
    readLoop1: LOOP

    FETCH table_cursor INTO codecount;  

        IF codecount=0 THEN
              LEAVE readLoop1;
        END IF; 

    SET codeName=(SELECT SUBSTRING_INDEX(inputCodeList,',',1)); 
    INSERT INTO test.code_table(CODE) SELECT codeName;
    SET inputCodeList=(SELECT TRIM(BOTH ',' FROM REPLACE(inputCodeList,codeName,'')));  
    INSERT INTO test.code_count(countNo) SELECT codecount-1;    
    SET codeName='';

    END LOOP;
    CLOSE table_cursor;
END;    

    -- use your code and description here, i guess those should be fixed
    SELECT CONCAT('["',REPLACE(GROUP_CONCAT(CASE WHEN CODE='A' THEN 'Apple'
               WHEN CODE = 'B' THEN 'Ball'
               WHEN CODE = 'C' THEN 'Cat'
               WHEN CODE = 'D' THEN 'Dog'
               ELSE '' END),',','","'),'"]') INTO finalString FROM test.code_table;

    RETURN finalString; 

END$$

DELIMITER ;

Попробуйте, сообщите мне, возникла ли какая-либо проблема.