我正在浏览MySQL中的一些数据,我需要从看起来像这样的列中删除一些信息。
**sometext** (something else)
遗憾的是,数据不一致;并非所有数据都遵循这种结构,其中一些只是第一部分。
**sometext**
所以我需要一种方法来删除括号之间的所有内容,然后删除括号本身,以便离开**sometext**
部分。
答案 0 :(得分:11)
使用此解决方案:
UPDATE tbl
SET txt = REPLACE(txt, SUBSTRING(txt, LOCATE('(', txt), LENGTH(txt) - LOCATE(')', REVERSE(txt)) - LOCATE('(', txt) + 2), '')
WHERE txt LIKE '%(%)%'
请记住,由于MySQL的最小正则表达式支持的限制,这不适用于(将返回空白):
(replacetext1) keepthistext1 (replacetext2) keepthistext2 (replacetext3)
...如果您想保留keepthistext1
和keepthistext2
,因为它会删除第一个左括号和最后一个右括号之间的所有。
答案 1 :(得分:2)
MySQL不支持正则表达式,因此唯一的方法是使用PHP等编写的外部程序,或者使用存储过程。
答案 2 :(得分:1)
您可以尝试使用函数SUBSTRING_INDEX
。
语法是:
SUBSTRING_INDEX(str,delim,count)
在这种情况下,它可能是:
UPDATE tbl
SET txt = (SELECT SUBSTRING_INDEX(txt, '(', 1));
虽然我没有检查过查询,但这会有所帮助。 有关此功能的进一步参考,您可以查看here
答案 3 :(得分:0)
您可以使用UDF(用户定义的函数)
查看https://launchpad.net/mysql-udf-regexp
所以你只需要创建与正则表达式匹配的括号,并使用普通的REPLACE语句和这个函数:)
答案 4 :(得分:0)
选择试试这个:
SELECT REPLACE('abdcejkhh klhklhkl (abc) agjkk',SUBSTRING('abdcejkhh klhklhkl (abc) agjkk',POSITION('(' IN 'abdcejkhh klhklhkl (abc) agjkk'),(length('abdcejkhh klhklhkl (abc) agjkk')-POSITION(')' IN 'abdcejkhh klhklhkl (abc) agjkk'))),'')
在更新声明中使用此功能。
答案 5 :(得分:0)
这是一个用户定义的函数,它可以在字符串中使用多个括号对
DELIMITER //
CREATE FUNCTION REMOVE_BRACKETS(input TEXT CHARACTER SET utf8 COLLATE utf8_bin)
RETURNS TEXT CHARACTER SET utf8 COLLATE utf8_bin
BEGIN
DECLARE output TEXT CHARACTER SET utf8 COLLATE utf8_bin DEFAULT '';
DECLARE in_brackets BOOL DEFAULT FALSE;
DECLARE length INT;
IF(input IS NULL)
THEN
RETURN NULL;
END IF;
WHILE(TRUE) DO
SET length = LOCATE(CASE WHEN in_parens THEN ']' ELSE '[' END, input);
IF(length = 0)
THEN
RETURN CONCAT(output, input);
END IF;
IF(in_brackets)
THEN
SET in_brackets = FALSE;
ELSE
SET output = CONCAT(output, SUBSTRING(input, 1, length - 1));
SET in_brackets = TRUE;
END IF;
SET input = SUBSTRING(input, length + 1);
END WHILE;
END //
DELIMITER ;