我有3个表,不知道如何创建一系列sql查询(或者如果可能,只创建一个复杂的查询)。这些表格是:
CREATE TABLE IF NOT EXISTS excerpt(
excerptID INT UNSIGNED NOT NULL AUTO_INCREMENT,
author VARCHAR(45) NOT NULL,
title VARCHAR(255) NOT NULL,
text VARCHAR(1000) NOT NULL,
comments VARCHAR(1000) NOT NULL,
PRIMARY KEY (excerptID)
) ENGINE=INNODB CHARACTER SET utf8mb4;
CREATE TABLE IF NOT EXISTS tag(
tagID INT UNSIGNED NOT NULL AUTO_INCREMENT,
description VARCHAR(45) NOT NULL ,
PRIMARY KEY (tagID)
) ENGINE=INNODB CHARACTER SET utf8mb4;
CREATE TABLE IF NOT EXISTS tagmap (
excerptID INT UNSIGNED NOT NULL,
tagID INT UNSIGNED NOT NULL,
PRIMARY KEY (excerptID, tagID),
CONSTRAINT excerptFK FOREIGN KEY (excerptID) REFERENCES excerpt (excerptID)
ON DELETE CASCADE
ON UPDATE CASCADE,
CONSTRAINT tagFK FOREIGN KEY (tagID) REFERENCES tag (tagID)
ON DELETE CASCADE
ON UPDATE CASCADE
) ENGINE=INNODB;
基于description参数,我需要返回与绑定到该描述的所有摘录相关的所有标记描述。举个例子,如果我有四个摘录
Excerpt(1, aaaa , aaaa, aaaa, aaaa) bound via tagmap to tags (A, B, C)
Excerpt(2, bbbb, bbbb, bbbb, bbbb) bound via tagmap tags (A, D)
Excerpt(3, cccc, cccc, cccc, cccc) bound via tagmap to tag (B)
Excerpt(4, dddd, ddddd, dddd, dddd) bound via tagmap to tags (B, D)
我的参数是“b”,我想返回摘录和描述的列表:
[Tag [excerptID=1, description=A], Tag [excerptID=1, description=B], Tag [excerptID=1, description=C], Tag [excerptID=3, description=B], Tag [excerptID=4, description=B], Tag [excerptID=4, description=D]]
到目前为止我有这个
String SQL = "SELECT e.excerptID, t.description from Excerpt AS e LEFT JOIN tagmap AS m ON m.excerptID = e.excerptID LEFT JOIN tag AS t ON t.tagID = m.tagID WHERE t.description = ?";
但这只会回报你
[Tag [excerptID=1, description=B], Tag [excerptID=3, description=B], Tag [excerptID=4, description=B]]
我不知道该怎么做。
1条答案
按热度按时间svgewumm1#
基于description参数,我需要返回与绑定到该描述的所有摘录相关的所有标记描述。举个例子,如果我有四个摘录
我相信这正是你想要的:
这看起来很复杂——也许是因为它很复杂。但子查询基本上是获取附加到同一实体的所有标记对。一个标签
tm2
)与你关心的描述有关。这就是问题所在t2.description = ?
在where
条款。另一个系在外桌的标签上。这就是相关条款
tm1.tagid = t.tagid
.另一种表达方式是这个查询(基本上是子查询):
返回包含您要查找的标记的实体上的所有标记。