mysql 判断字符串是否有交集

mysql 判断字符串是否有交集,第1张

DROP FUNCTION IF EXISTS `INTE_ARRAY` delimiter // -- 集合交集检查函数 -- @param varchar(255) setA A 集合 如 "1,3,5,9" -- @param varchar(255) setB B 集合 如 "8,2,3,7" -- @return int(1) B 集合内单元在 A集合 内存在则返回 1 否则返回 0 CREATE FUNCTION `INTE_ARRAY` (setA varchar(255),setB varchar(255)) RETURNS int(1) BEGIN DECLARE idx INT DEFAULT 0 -- B 集合单元索引 DECLARE len INT DEFAULT 0-- B 集合表达式长度 DECLARE llen INT DEFAULT 0-- 最后检查位置 DECLARE clen INT DEFAULT 0-- 当前检查位置 DECLARE tmpStr varchar(255)-- 临时检查数据集 DECLARE curt varchar(255)-- B 当前检查的单元 SET len = LENGTH(setB) WHILE idx <len DO SET idx = idx + 1 SET tmpStr = SUBSTRING_INDEX(setB,",",idx) SET clen = LENGTH(tmpStr) -- 获取当前 setB 中的单元 IF idx = 1 THEN SET curt = tmpStr ELSE SET curt = SUBSTRING(setB,llen+2,clen-llen-1) END IF -- 检查是否存在于 setA 中 IF FIND_IN_SET(curt,setA) >0 THEN RETURN 1 END IF -- 当前检查终点与上次检查终点相同则跳出 IF clen <= llen THEN RETURN 0 END IF SET llen = clen END WHILE RETURN 0 END // delimiter select INTE_ARRAY("1,3,5,9","8,2,3,7") as is_inte_array --select INTE_ARRAY("1,3,5,9","2,8,6,10") as is_inte_array --select INTE_ARRAY("10,3,5,9","2,8,6,10") as is_inte_array --select INTE_ARRAY("1,30,5,9","2,8,6,10") as is_inte_array --select INTE_ARRAY("1,30,5,9","2,30,6,10") as is_inte_array

在PHP中求数组的交集,我们可以与PHP给我们提供的现成函数:array_intersect(),其用法格式为:

array array_intersect(array array1,array array2[,arrayN…])

根据上述的语法格式,我们来写一个例子:

1<?php

2$fruit1 = array("Apple","Banana","Orange")

3$fruit2 = array("Pear","Apple","Grape")

4$fruit3 = array("Watermelon","Orange","Apple")

5$intersection = array_intersect($fruit1, $fruit2, $fruit3)

6print_r($intersection)

7// 输出结果:

8// Array ( [0] =>Apple )

9?>

本例子将返回在$fruit1数组中出现且在$fruit2和$fruit3中也出现的所有水果的名子。

使用array_intersect()函数时要注意:只有在两个元素相等且具有相同的数据类型时,array_intersect()函数才会认

为它们是相同的,否则不能进行交集计算。array_intersect()函数返回一个保留了键的数组,只由第一个数组中出现的且在其它数组中都出现的

值组成。

若要求关联数组的交集,请使用array_intersect_assoc()函数,给你个简单的例子:

1<?php

2$fruit1 = array("red"=>"Apple","yellow"=>"Banana","orange"=>"Orange")

3$fruit2 = array("yellow"=>"Pear","red"=>"Apple","purple"=>"Grape")

4$fruit3 = array("green"=>"Watermelon","orange"=>"Orange","red"=>"Apple")

5$intersection = array_intersect_assoc($fruit1, $fruit2, $fruit3)

6print_r($intersection)

7// 输出:

8// Array ( [red] =>Apple )

9?>

array_intersect_assoc()函数语法格式如下:

array array_intersect_assoc(array array1,array array2[,arrayN…])

array_intersect_assoc()与array_intersect()基本相同,只不过他在比较中还考虑了数组的键。因此,只有在第一个数组中出现,且在所有其他输入数组中也出现的键/值对才返回到结果数组中。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7340578.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-04
下一篇 2023-04-04

发表评论

登录后才能评论

评论列表(0条)

保存