首頁  >  問答  >  主體

mysql - 字串根據字典替換

來源表:

字典表:

期望將來源表的數值依字典表替換,目標結果如下:

#嘗試過用replace函數,但是只能單一替換.
(註:其他由於是逗號分隔,字典表id可1~100,需要用正規表示式替換,否則12會被id1,2拆開)

PHPzPHPz2686 天前929

全部回覆(1)我來回復

  • 给我你的怀抱

    给我你的怀抱2017-05-18 10:52:38

    自己寫的遞歸函數

    DELIMITER $$
    DROP FUNCTION IF EXISTS junk.StringReplaceSplit $$
    CREATE FUNCTION junk.StringReplaceSplit (v_str VARCHAR(1024), v_split VARCHAR(1024)) RETURNS VARCHAR(1024)
    DETERMINISTIC
    BEGIN
      DECLARE rv VARCHAR(1024);
      DECLARE splist_count INT;
      DECLARE i INT;
      DROP TEMPORARY TABLE IF EXISTS tmp_table;
      CREATE TEMPORARY TABLE tmp_table(v_key VARCHAR(100));
     
      SET i = 1;
      set splist_count = (length(v_str)-length(replace(v_str, v_split,'')))/length(v_split)+1;
      WHILE i <= splist_count DO
        INSERT INTO tmp_table
          SELECT REPLACE(substring(substring_index(v_str, v_split, i),
                         length(substring_index(v_str, v_split, i-1)) + 1),
                          v_split, '');
        SET i = i + 1;
      END WHILE;
      SELECT replace(group_concat(ifnull(wordlist.word, tmp_table.v_key)), ',', v_split) INTO rv
        from tmp_table
        LEFT JOIN wordlist on wordlist.id=tmp_table.v_key;
      RETURN rv;
    END $$
    DELIMITER ;

    效果:
    源表

    mysql> select * from teststring;
    +----+----------------------------+
    | id | String                     |
    +----+----------------------------+
    |  1 | 1,2,3,4,5                  |
    |  2 | 4,5,7,8,84                 |
    |  3 | key,23,344,12,3,9,34,3,1,3 |
    +----+----------------------------+
    3 rows in set (0.00 sec)
    

    字典表

    mysql> select * from wordlist;
    +----+-------+
    | id | word  |
    +----+-------+
    | 1  | one   |
    | 2  | two   |
    | 3  | three |
    | 4  | four  |
    | 5  | five  |
    | 7  | six   |
    | 8  | eight |
    | 9  | nine  |
    | 10 | ten   |
    +----+-------+
    9 rows in set (0.00 sec)

    範例:

    mysql> SELECT id, StringReplaceSplit(String,',') transform from teststring ;
    +----+---------------------------------------------+
    | id | transform                                   |
    +----+---------------------------------------------+
    |  1 | one,two,three,four,five                     |
    |  2 | four,five,six,eight,84                      |
    |  3 | key,23,344,12,three,nine,34,three,one,three |
    +----+---------------------------------------------+
    3 rows in set (0.04 sec)

    函數有待最佳化.

    回覆
    0
  • 取消回覆