我在mysql中创建了以下函数:

DELIMITER $$
CREATE FUNCTION fn_header_uploader_address(v_add varchar(500)) RETURNS bigint(20)
begin
DECLARE v_error bigint default 0;

    IF length(v_add) > 100 then
        set v_error = 110;
    elseif v_add is null or v_add ='' then
        set v_error=110;
    elseif v_add NOT REGEXP '^[A-Z0-9._%-]+@[A-Z0-9.-]+\.[A-Z]{2,4}$' then
        set v_error=110;
    end if;
return v_error;

end$$
DELIMITER ;


如果我在本地(确定性/无确定性子句)上运行它,则它为以下语句返回零(有效电子邮件):

select fn_header_uploader_address('hello@gmail.com');


但是在将功能移到新服务器上时,这变得区分大小写!
所以现在

select fn_header_uploader_address('hello@gmail.com'); ---- error 110


有什么帮助吗?

编辑:

我已经使用以下命令比较了服务器:

show collation where collation like '%_c%' ;
show variables like '%version%';

最佳答案

更改:

...
elseif v_add NOT REGEXP '^[a-zA-Z0-9._%-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4}$' then
...


或二进制:

...
elseif v_add NOT REGEXP '^[\x41-\x5a\x61-\x7a\x30-\x39\x2e\x2d\x5f\x25]+\x40[\x41-\x5a\x61-\x7a\x30-\x39\x2e\x2d]+\x2e[\x41-\x5a\x61-\x7a]{2,4}$' then
...

关于mysql - 功能在其他服务器上区分大小写,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/26771726/

10-11 02:49
查看更多