我想将以下 Oracle REGEXP_COUNT 函数重写为 MariaDB 10.3。我正在尝试使用 LENGTH 概念重写,但无法获得有效结果。
我正在使用这样的^((((https?|ftps?|gopher|telnet|nntp):\/\/)|(mailto:|news:))(%[0-9A-Fa-f]{2}|[-()_.!~*\'';/?:@&=+$,A-Za-z0-9])+)([).!/?:,][[:blank:]])?$
模式和代码:
SET SQL_MODE=ORACLE;
DELIMITER //
CREATE OR REPLACE FUNCTION "IS_VALID"(VALUE TEXT) RETURN double
IS
is_valid DECIMAL (1, 0);
BEGIN
is_valid := 0;
IF REGEXP_COUNT(VALUE, '^((((https?|ftps?|gopher|telnet|nntp):\/\/)|(mailto:|news:))(%[0-9A-Fa-f]{2}|[-()_.!~*\'';/?:@&=+$,A-Za-z0-9])+)([).!/?:,][[:blank:]])?$') = 1
THEN
is_valid := 1;
END IF
RETURN is_valid;
END;//
DELIMITER ;