gpt4 book ai didi

MySQL 查询从单个表中查找相关行

转载 作者:行者123 更新时间:2023-11-29 19:15:02 26 4
gpt4 key购买 nike

我有一个附加的表结构 News在 MySQL 数据库中。

问题是 id=1 时,我在标签列中有 AI、BOTS 等标签。因此,当我使用 id=1 进行查询时,我需要获取包含 AI 或 BOTS 的所有行。因此输出将是 id=1、id=3 和 id=4 的行。同样,如果我查询 id=4,我应该得到第 1 行和第 4 行。

我尝试查询

Select * From news where tags in (select tags from news where id=1); 

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

最佳答案

使用 find_in_set_extra 创建一个新函数名称

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<

使用此功能,您可以找到类似的数据

find_in_set_extra('a,b,c','b,c')

关于MySQL 查询从单个表中查找相关行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42781859/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com