Найти несколько идентификаторов, хранящихся в строке в Mysql - PullRequest
1 голос
/ 15 апреля 2019

У меня есть строка, которая выглядит так: pi_18944000_780345308_54210001000_345900_text

Как извлечь все идентификаторы, находящиеся в нем, и сохранить его?

Я пробовал что-то вроде этого:


    set @a = (SELECT
      SUBSTRING(SUBSTRING(SUBSTRING('pi_18944000_780345308_54210001000_345900_text',
     (LOCATE('_', 'pi_18944000_780345308_54210001000_345900_text'))), 2), 1, 
    LOCATE('_', SUBSTRING(SUBSTRING('pi_18944000_780345308_54210001000_345900_text',
     (LOCATE('_', 'pi_18944000_780345308_54210001000_345900_text'))), 2)) - 1)
    ); 
    select @a;

set @b = (SELECT
  SUBSTRING(SUBSTRING(SUBSTRING(SUBSTRING(SUBSTRING(
  'pi_18944000_780345308_54210001000_345900_text'  , (  LOCATE('_',  'pi_18944000_780345308_54210001000_345900_text'  ))  ), 2),
  LOCATE('_', SUBSTRING(SUBSTRING(  'pi_18944000_780345308_54210001000_345900_text',  (  LOCATE('_', 'pi_18944000_780345308_54210001000_345900_text'
  ))), 2))), 2), 1, LOCATE('_', SUBSTRING(SUBSTRING(SUBSTRING(SUBSTRING(  'pi_18944000_780345308_54210001000_345900_text'  , (
  LOCATE(  '_',  'pi_18944000_780345308_54210001000_345900_text'  ))), 2),
  LOCATE('_',  SUBSTRING(SUBSTRING(  'pi_18944000_780345308_54210001000_345900_text',  (
  LOCATE('_',  'pi_18944000_780345308_54210001000_345900_text'  )))  , 2))), 2)) - 1) );

select @b;

Это работает, но это действительно сложно. Просто хотел посмотреть, есть ли лучший способ сделать это?

1 Ответ

2 голосов
/ 15 апреля 2019

Вот несколько более простое решение. Он использует встроенную функцию SUBSTRING_INDEX(). Требуется ссылка на строковое выражение только один раз.

mysql> set @str = 'pi_18944000_780345308_54210001000_345900_text';

mysql> SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(@str, '_', 3), '_', -1) AS n;
+-----------+
| n         |
+-----------+
| 780345308 |
+-----------+

См. https://dev.mysql.com/doc/refman/8.0/en/string-functions.html#function_substring-index

В следующий раз вам не следует хранить несколько идентификаторов в строке, если вам нужно ссылаться на отдельные идентификаторы в выражении SQL.

...