How to remove all non-alpha numeric characters from a string in MySQL?(如何从 MySQL 中的字符串中删除所有非字母数字字符?)
问题描述
我正在研究一个比较字符串的例程,但为了提高效率,我需要删除所有不是字母或数字的字符.
I'm working on a routine that compares strings, but for better efficiency I need to remove all characters that are not letters or numbers.
我现在使用多个 REPLACE 函数,但也许有更快更好的解决方案?
I'm using multiple REPLACE functions now, but maybe there is a faster and nicer solution ?
推荐答案
使用 MySQL 8.0 或更高版本
由下面 michal.jakubeczy 的回答提供,MySQL 现在支持用 Regex 替换:
Using MySQL 8.0 or higher
Courtesy of michal.jakubeczy's answer below, replacing by Regex is now supported by MySQL:
UPDATE {table} SET {column} = REGEXP_REPLACE({column}, '[^0-9a-zA-Z ]', '')
使用 MySQL 5.7 或更低版本
此处不支持正则表达式.我必须创建自己的名为 alphanum 的函数,它为我去除了字符:
Using MySQL 5.7 or lower
Regex isn't supported here. I had to create my own function called alphanum which stripped the chars for me:
DROP FUNCTION IF EXISTS alphanum;
DELIMITER |
CREATE FUNCTION alphanum( str CHAR(255) ) RETURNS CHAR(255) DETERMINISTIC
BEGIN
DECLARE i, len SMALLINT DEFAULT 1;
DECLARE ret CHAR(255) DEFAULT '';
DECLARE c CHAR(1);
IF str IS NOT NULL THEN
SET len = CHAR_LENGTH( str );
REPEAT
BEGIN
SET c = MID( str, i, 1 );
IF c REGEXP '[[:alnum:]]' THEN
SET ret=CONCAT(ret,c);
END IF;
SET i = i + 1;
END;
UNTIL i > len END REPEAT;
ELSE
SET ret='';
END IF;
RETURN ret;
END |
DELIMITER ;
现在我可以:
select 'This works finally!', alphanum('This works finally!');
我得到:
+---------------------+---------------------------------+
| This works finally! | alphanum('This works finally!') |
+---------------------+---------------------------------+
| This works finally! | Thisworksfinally |
+---------------------+---------------------------------+
1 row in set (0.00 sec)
万岁!
这篇关于如何从 MySQL 中的字符串中删除所有非字母数字字符?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何从 MySQL 中的字符串中删除所有非字母数字字符?
基础教程推荐
- 如何在 SQL 中将 Float 转换为 Varchar 2021-01-01
- MySQL 中的类型:BigInt(20) 与 Int(20) 2021-01-01
- 表 './mysql/proc' 被标记为崩溃,应该修复 2022-01-01
- 如何根据该 XML 中的值更新 SQL 中的 XML 2021-01-01
- 什么是 orradiag_<user>文件夹? 2022-01-01
- 二进制文件到 SQL 数据库 Apache Camel 2021-01-01
- 在 MySQL 中:如何将表名作为存储过程和/或函数参数传递? 2021-01-01
- mysql选择动态行值作为列名,另一列作为值 2021-01-01
- 在多列上分布任意行 2021-01-01
- oracle区分大小写的原因? 2021-01-01
