MySQL删除两个括号之间的字符

时间:2012-08-31 11:12:34

标签: mysql sql

我正在浏览MySQL中的一些数据,我需要从看起来像这样的列中删除一些信息。

**sometext** (something else)

遗憾的是,数据不一致;并非所有数据都遵循这种结构,其中一些只是第一部分。

**sometext**

所以我需要一种方法来删除括号之间的所有内容,然后删除括号本身,以便离开**sometext**部分。

6 个答案:

答案 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)

...如果您想保留keepthistext1keepthistext2,因为它会删除第一个左括号和最后一个右括号之间的所有

SQLFiddle Demo

答案 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 ;