首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从数据库字段中删除特殊字符

从数据库字段中删除特殊字符
EN

Stack Overflow用户
提问于 2011-05-20 10:43:01
回答 9查看 99.6K关注 0票数 17

我有一个包含数千条记录的数据库,我需要剥离其中一个字段,以确保它只包含某些字符(字母数字、空格和单引号)。我可以使用什么SQL从整个数据库中的该字段中剥离任何其他字符(如斜杠等)?

EN

回答 9

Stack Overflow用户

回答已采纳

发布于 2011-05-20 10:56:17

代码语言:javascript
复制
update mytable
set FieldName = REPLACE(FieldName,'/','')

这是一个很好的起点。

票数 33
EN

Stack Overflow用户

发布于 2018-03-06 19:03:46

我已经为此创建了一个简单的函数

代码语言:javascript
复制
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

用法示例:

代码语言:javascript
复制
SELECT <field-name> AS NormalText, regex_replace('[^A-Za-z0-9 ]', '', <field-name>)AS RegexText FROM 
<table-name>
票数 6
EN

Stack Overflow用户

发布于 2011-05-20 11:46:42

Replace()函数是首选方法。但是,在控制台中编写特殊字符有时会很棘手。对于那些,您可以将Replace与Char()函数结合使用。

例如,移除欧元

代码语言:javascript
复制
Update products set description = replace(description, char(128), '');

你可以找到所有的Ascii values here

理想情况下,您可以执行正则表达式来查找所有特殊字符,但显然是that's not possible with MySQL.

除此之外,您还需要通过您最喜欢的脚本语言来运行它。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6066953

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档