Heim > Datenbank > MySQL-Tutorial > mysql自定义函数实现字符串匹配_MySQL

mysql自定义函数实现字符串匹配_MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2016-06-01 13:30:20
Original
1053 Leute haben es durchsucht

bitsCN.com

mysql自定义函数实现字符串匹配
 

先来一个截图:

fSearch函数的第一个参数为单一字符串(即 没有特殊字符串隔开)

mysql自定义函数实现字符串匹配_MySQL

fSearch函数的第一个参数非单一字符串

mysql自定义函数实现字符串匹配_MySQL

多个字符串同样可以匹配。

 

函数代码:

01DELIMITER $$02Create   function fSearch(targetStr VARCHAR(100),findStr VARCHAR(100)) RETURNS INT03BEGIN04DECLARE strNum INT;05DECLARE cIndex INT DEFAULT 1;06DECLARE cStr VARCHAR(50);07DECLARE flag INT;08set strNum=1+(length(targetStr) - length(replace(targetStr,&#39;,&#39;,&#39;&#39;)));09WHILE cIndex<=strNum10DO11set cStr=reverse(substring_index(reverse(substring_index(targetStr,&#39;,&#39;,cIndex)),&#39;,&#39;,1));12set flag=LOCATE(cStr,findStr);13if (flag>0&&cStr!=&#39;&#39;) THEN14RETURN flag;15END IF;16set cIndex=cIndex+1;17END WHILE;18RETURN 0;19END $$20DELIMITER ;
Nach dem Login kopieren

使用场景:

加入博客系统中有个字段 存储文章所属的标签,假设标签为‘java,php,asp,web开发’ ,此时如果想通过该标签找到具有同类标签的文章 则可:

select *from blog b where fSearch(&#39;java,php,asp,web开发&#39;,b.tags)>0
Nach dem Login kopieren

 


bitsCN.com
Verwandte Etiketten:
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage