在我的表格中,我有这样的字符串:
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环境中运行。
答案 0 :(得分: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$';