PHP试题网_中国最大的免费网络PHP试题测试平台,PHP试卷调查,PHP试卷模板、PHP考试测验

方法1:自定义mysql函数

假如我有两个字符串str1:'1001,1002,1003,1004',str2:'1001,2001,3001,4001'。

 

现在需要判断这两个以逗号分割的字符串是否存在交集,则可以创建一个mysql函数来实现。

 

代码如下: 

#创建FUNCTION

DELIMITER $$;

 

CREATE FUNCTION `is_mixed`(str1 TEXT, str2 TEXT) RETURNS TINYINT

    BEGIN

    DECLARE ismixed TINYINT DEFAULT 0;

    set ismixed:=(select concat(str1, ',') regexp concat(replace(str2,',',',|'), ','));

    RETURN ismixed;

    END;$$

 

DELIMITER ;

 

#执行FUNCTION

select is_mixed('1001,1002,1003,1004', '1001,2001,3001,4001');

 

由于MySQL没有布尔类型, 所以选择了tinyint类型的1和0来表示true 和 false。

 

执行结果:返回结果为1,表示true, 存在交集。


注:群主一直没有试成功过。



方法2:正则

2017-03-05_13-34-09.png



select * from tmp where concat(',',value,',') regexp concat(',(14|15),');


2017-03-05_13-36-38.png

至此,通过正则可以匹配到数据,完美解决问题。


作者:OK兄 浏览次数:64

登 录