我有一个包含数千条记录的数据库,我需要剥离其中一个字段,以确保它只包含某些字符(字母数字、空格和单引号)。我可以使用什么SQL从整个数据库中的该字段中剥离任何其他字符(如斜杠等)?
发布于 2011-05-20 10:56:17
update mytable
set FieldName = REPLACE(FieldName,'/','')这是一个很好的起点。
发布于 2018-03-06 19:03:46
我已经为此创建了一个简单的函数
DROP FUNCTION IF EXISTS `regex_replace`$$
CREATE FUNCTION `regex_replace`(pattern VARCHAR(1000),replacement VARCHAR(1000),original VARCHAR(1000)) RETURNS VARCHAR(1000) CHARSET utf8mb4
DETERMINISTIC
BEGIN
DECLARE temp VARCHAR(1000);
DECLARE ch VARCHAR(1);
DECLARE i INT;
SET i = 1;
SET temp = '';
IF original REGEXP pattern THEN
loop_label: LOOP
IF i>CHAR_LENGTH(original) THEN
LEAVE loop_label;
END IF;
SET ch = SUBSTRING(original,i,1);
IF NOT ch REGEXP pattern THEN
SET temp = CONCAT(temp,ch);
ELSE
SET temp = CONCAT(temp,replacement);
END IF;
SET i=i+1;
END LOOP;
ELSE
SET temp = original;
END IF;
RETURN temp;
END用法示例:
SELECT <field-name> AS NormalText, regex_replace('[^A-Za-z0-9 ]', '', <field-name>)AS RegexText FROM
<table-name>发布于 2011-05-20 11:46:42
Replace()函数是首选方法。但是,在控制台中编写特殊字符有时会很棘手。对于那些,您可以将Replace与Char()函数结合使用。
例如,移除欧元
Update products set description = replace(description, char(128), '');你可以找到所有的Ascii values here
理想情况下,您可以执行正则表达式来查找所有特殊字符,但显然是that's not possible with MySQL.
除此之外,您还需要通过您最喜欢的脚本语言来运行它。
https://stackoverflow.com/questions/6066953
复制相似问题