我在将两个查询合并为一个查询时遇到问题。我的示例数据库如下所示:https://www.db-fiddle.com/f/b2hsqiqzfqrdhrxzrmm49m/4
我想给出与第一个查询及其标记匹配的所有项目:
标题、说明、标签//链接中的查询#3
我遇到的主要问题是从一个查询到另一个查询的数据传输。item.iditem=112,其中112是来自第一个查询的idit。我的尝试:
SELECT title, description, i.idItem
FROM tags t INNER JOIN
itemtags it
ON t.idTag = it.idtag INNER JOIN
item i ON it.idItem = i.idItem
WHERE t.name = "java";
SELECT GROUP_CONCAT(`Name`) as tags
FROM tags
WHERE idtag IN ( SELECT it.idtag FROM itemtags it,tags t WHERE it.idtag=t.idtag AND it.iditem = 112);
SELECT *
FROM (SELECT title, description FROM tags t INNER JOIN itemtags it ON t.idTag = it.idtag INNER JOIN item i ON it.idItem = i.idItem WHERE t.name = "java") as x,
(SELECT GROUP_CONCAT(`Name`) as tags FROM tags JOIN itemtags ON tags.idtag = itemtags.idtag INNER JOIN item ON itemtags.iditem = item.iditem AND item.iditem = 112) as y;
2条答案
按热度按时间mdfafbf11#
以下是我的尝试:
它显示每个项目的标题和描述,其中有一个名为“java”的标记,还有一列包含为该项目记录的所有标记的串联。
可以更改条件标记名称
"java"
到其他名称,通过更改条件来显示具有特定标记的项WHERE t.name="java"
至WHERE t.name="frontend"
例如。注意:我必须使用
DISTINCT
在外太空的开始SELECT
查询和内部GROUP_CONCAT
函数忽略中的重复记录itemtags
您提供的示例数据库中的表。我也在db fiddle中测试了查询:https://www.db-fiddle.com/f/b2hsqiqzfqrdhrxzrmm49m/13
ih99xse12#
我将用ids展示逻辑。您可以填写查询的其余部分来处理带有附加联接的名称。
其思想是自连接,然后聚合。关键是要计算匹配标签的数量,看看匹配的数量是否涵盖了所讨论项目的所有标签: