0

在我的表中,我有这样的字符串:

Quisque scelerisque, odio ut ornare faucibus - IR:5443_XP
Maecenas eleifend felis in - IR:2077_XP

在上面的字符串中,我只需要提取数字 (5443, 2077) 并将数据转换为如下内容:

Quisque scelerisque, odio ut ornare faucibus - Model ID = 5443
Maecenas eleifend felis in - Model ID = 2077

我在数据库中有大量这些需要更改。我怎样才能在 MySQL 中做到这一点?我不认为 MySQL 的“REGEXP”功能强大到足以做到这一点。我想我需要使用子表达式来存储数字,然后将它们取回以将文本更新为第二种格式。

我看过这个:http ://www.mysqludf.org/lib_mysqludf_preg/但我无法让它在我的 xampp 环境中运行。

4

1 回答 1

0

如果没有 UDF,我可能会做这样的事情。

SELECT
    `text` AS 'original_text',
    IF(`text` REGEXP '[[:<:]]IR:[0-9]+_XP$',
        CONCAT(
            SUBSTRING_INDEX(`text`,CONCAT('IR:',SUBSTRING_INDEX(`text`,'IR:',-1)),1),
            'Model ID = ',
            SUBSTRING_INDEX(SUBSTRING_INDEX(`text`,'IR:',-1),'_',1
        )
     ),`text`) AS 'modified_text'
FROM `example_table`

具有如下表结构:

CREATE TABLE `example_table` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `text` text,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;

不过,我不确定这会有多快或多有效。

编辑:

对不起SELECT版本。这是UPDATE一个:

UPDATE `example_table`
SET `text` = CONCAT(
    SUBSTRING_INDEX(`text`,CONCAT('IR:',SUBSTRING_INDEX(`text`,'IR:',-1)),1),
    'Model ID = ',
    SUBSTRING_INDEX(SUBSTRING_INDEX(`text`,'IR:',-1),'_',1)
)
WHERE `text` REGEXP '[[:<:]]IR:[0-9]+_XP$';
于 2012-07-19T12:50:17.617 回答