下面两个函数的使用和FIND_IN_SET一样,使用时只需要把FIND_IN_SET换成FIND_PART_IN_SETFIND_ALL_PART_IN_SET

例如某字段里是为1,2,3,4,5

使用方法:

第一种,传入1,3,6 可以查出来

select * from XXX where FIND_PART_IN_SET('1,3,6','1,2,3,4,5')
select * from XXX where FIND_ALL_PART_IN_SET('1,3,6','1,2,3,4,5')

第一种:只要包含其中一个就可以被查出来

CREATE DEFINER = `root`@`%` FUNCTION `NewProc`(str1 text,str2 text) RETURNS textBEGIN #传入两个逗号分割的字符串,判断第二个字符串是否包含第一个字符串split之后的单个DECLARE CURRENTINDEX INT;#当前下标DECLARE CURRENTSTR text;DECLARE result int;set result = 0;set CURRENTINDEX = 0;set CURRENTSTR = '';IF str1 IS NOT NULL AND str1 != '' THEN SET CURRENTINDEX = LOCATE(',',str1); WHILE CURRENTINDEX > 0 DO SET CURRENTSTR = substring(str1,1,CURRENTINDEX-1); if FIND_IN_SET(CURRENTSTR,str2) THEN  set result = 1; end if; SET str1 = substring(str1,CURRENTINDEX+1); SET CURRENTINDEX = LOCATE(',',str1); END WHILE; #只传一个 和 最后无逗号的情况 IF LENGTH(str1) > 0 THEN if FIND_IN_SET(str1,str2) THEN  set result = 1; end if; END IF;END IF;RETURN result;END;
CREATE DEFINER = `root`@`%` FUNCTION `NewProc`(str1 text,str2 text) RETURNS textBEGIN #传入两个逗号分割的字符串,判断第二个字符串是否全部包含第一个字符串split之后的单个DECLARE CURRENTINDEX INT;#当前下标DECLARE CURRENTSTR text;DECLARE RESULT int;DECLARE TOTALCOUNT int;DECLARE TRUECOUNT int;set RESULT = 0;set CURRENTINDEX = 0;set CURRENTSTR = '';set TOTALCOUNT = 0;set TRUECOUNT = 0;IF str1 IS NOT NULL AND str1 != '' THEN SET CURRENTINDEX = LOCATE(',',str1); WHILE CURRENTINDEX > 0 DO SET TOTALCOUNT = TOTALCOUNT + 1; SET CURRENTSTR = substring(str1,1,CURRENTINDEX-1); if FIND_IN_SET(CURRENTSTR,str2) THEN  SET TRUECOUNT = TRUECOUNT + 1; end if; SET str1 = substring(str1,CURRENTINDEX+1); SET CURRENTINDEX = LOCATE(',',str1); END WHILE; #只传一个 和 最后无逗号的情况 IF LENGTH(str1) > 0 THEN SET TOTALCOUNT = TOTALCOUNT + 1; if FIND_IN_SET(str1,str2) THEN  SET TRUECOUNT = TRUECOUNT + 1; end if; END IF;END IF;IF TOTALCOUNT > 0 AND TRUECOUNT = TOTALCOUNT THEN  SET RESULT = 1;END IF;RETURN result;END;

更多相关文章

  1. 浅谈Java中Collections.sort对List排序的两种方法
  2. 创建android逐帧动画的两种方式
  3. TabHost两种实现方式
  4. Android-两种方式实现走马灯效果
  5. Android(安卓)通知Notification的两种实现方法
  6. android之MultiAutoCompleteTextView
  7. Android菜单实现两种方式
  8. android edittext 显隐密码代码转换两种方式
  9. android使用同一个RecyclerView实现两种不同Item布局

随机推荐

  1. 基于内容估计文本宽度的算法
  2. JavaScript中的map()函数
  3. Java面试题--基础知识部分
  4. Hbase1.1.x Java版之批量查删操作
  5. 【Servlet】使用org.eclipse.jetty实现小
  6. java中的成员变量和局部变量的区别
  7. java 中判断一个字符串中大小写字母的个
  8. RxJava理解系列(一)
  9. 这是我在Java套接字编程中做的一种大家都
  10. java 和 C 代码运行效率的比较(整理)