我正在寻找在表中查找与用户输入的特定数字匹配的记录。因此,用户可以输入12345,但是在数据库中可以是123zz4-5。
我想如果PHP函数可以在MySQL中工作,那么类似的事情就可以工作。
SELECT * FROM foo WHERE preg_replace("/[^0-9]/","",bar) = '12345' 仅MySQL的等效功能或方法是什么?
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
我意识到这是一个古老的话题,但是在搜索了这个问题后,我找不到一个简单的解决方案(我看到了古老的代理,但认为这是一个更简单的解决方案),所以这是我编写的一个函数,似乎工作得很好。
DROP FUNCTION IF EXISTS STRIP_NON_DIGIT; DELIMITER $$ CREATE FUNCTION STRIP_NON_DIGIT(input VARCHAR(255)) RETURNS VARCHAR(255) BEGIN DECLARE output VARCHAR(255) DEFAULT ''; DECLARE iterator INT DEFAULT 1; WHILE iterator < (LENGTH(input) + 1) DO IF SUBSTRING(input, iterator, 1) IN ( '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' ) THEN SET output = CONCAT(output, SUBSTRING(input, iterator, 1)); END IF; SET iterator = iterator + 1; END WHILE; RETURN output; END $$ 来源:stack overflow