首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用于从单个表中查找相关行的MySQL查询

用于从单个表中查找相关行的MySQL查询
EN

Stack Overflow用户
提问于 2017-03-14 17:13:35
回答 1查看 110关注 0票数 0

我有一个附呈的表格结构

在MySQL数据库中。

问题是对于id=1,我有像AI这样的标签,在标签列中有机器人。因此,当我使用id=1进行查询时,我需要获取所有包含AI或机器人的行。因此,输出将是包含id=1、id=3和id=4的行。类似地,如果我使用id=4查询,我应该得到第1行和第4行。

我尝试过查询

代码语言:javascript
复制
Select * From news where tags in (select tags from news where id=1); 

但这并没有帮助。我在编写复杂的数据库查询方面没有太多的专业知识,如果有任何帮助,我将不胜感激。

EN

回答 1

Stack Overflow用户

发布于 2017-03-14 17:26:37

使用find_in_set_extra创建新的函数名

代码语言:javascript
复制
BEGIN
DECLARE limitCount INT DEFAULT 0;
DECLARE counter INT DEFAULT 0;
DECLARE res INT DEFAULT 0;
DECLARE temp TEXT;
SET limitCount = 1 + LENGTH(inputList) - LENGTH(REPLACE(inputList, ',',''));
simple_loop:LOOP
SET counter = counter + 1;
SET temp = SUBSTRING_INDEX(SUBSTRING_INDEX(inputList,',',counter),',',-1);
SET res = FIND_IN_SET(temp,targetList);
IF res > 0 THEN LEAVE simple_loop; END IF;
IF counter = limitCount THEN LEAVE simple_loop; END IF;
END LOOP simple_loop;
RETURN res;
END<

使用此函数,您可以找到如下数据

代码语言:javascript
复制
find_in_set_extra('a,b,c','b,c')
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42781859

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档