Mysql正在获取所有联接的记录—两个表


Mysql getting all joined records both tables

我正在使用一个很棒的php框架来处理我的数据库medoo.php。链接到medoo文档以供参考:http://medoo.in/doc

我想发生什么:

  • 返回联接表中的所有记录,其中它与右表中的一个或多个条件相匹配。(主表为"items")
  • 包括右表中的匹配/联接记录。(在这种情况下,返回了与"items"相关的所有"tags")

当前正在发生的事情:

  • 返回与右表(标记)连接的左表(项)中的记录。但是,它只返回显式包含WHERE条件中的标记的记录。我希望所有标记都连接到具有匹配WHERE条件的标记的项上的项

让我们获取一些代码来更好地说明这个问题:

//example 'items' table
    id    -   123
    name  -   'test'
    desc  -   'testing'
//example 'tags' table
    id    -   100
    name  -   'tag1'
//example 'taglist' table (relational)
    id      -   10
    itemid  -   123
    tagid   -   100

这说明了基本设置,为了清晰起见,将其最小化。

然后,使用medoo,我从"items"和带有左联接的联接标记/标记列表中进行选择(当前)。WHERE子句:tag.id与要搜索的已发布tagid匹配。还在WHERE中尝试了taglist.tagid。

正如您所期望的,返回的结果是包含与WHERE子句匹配的标记的所有"items"。然而,我想要所有与这些项目相关的标签,而不仅仅是我搜索的标签(这就是我得到的)。

我想这一定与JOIN或WHERE子句有关,但我必须说,经过数小时的尝试、研究和更多的尝试,我迷失了方向。希望有人能帮我一把,发现我的逻辑可能出错的地方。

为了进一步参考,以下是使用medoo的完整查询设置。

//setup query
$table = 'items';
$join = [
    "[>]taglist(tl)" => ["id" => "itemid"],
    "[>]filelist(fl)" => ["id" => "itemid"],
    "[>]tags(t)" => ["tl.tagid" => "id"],
    "[>]files(f)" => ["fl.fileid" => "id"]
];
$cols = [
    "items.id(id)",
    "items.itemid(itemid)",
    "items.name(name)",
    "items.def(def)",
    "items.class(class)",
    "items.timeline(timeline)",
    "t.id(tagid)",
    "t.name(tagname)",
    "f.id(fileid)",
    "f.name(filename)",
    "f.path(filepath)",
    "f.type(filetype)",
    "tl.tagid"
];
$where = [
    "AND" => ["tl.tagid" => $tags],
    "ORDER" => ["items.id DESC","t.name ASC"],
    "LIMIT" => [$start,$limit]
];
// Do query
$results = $db->select($table, $join, $cols, $where);

如果您不熟悉medoo,这仍然应该说明如何简单地设置查询。(查询工作得很好,只是没有得到我想要的所有结果)。

谢谢你的建议。这周我学到了很多!

如果先执行leftside LEFT JOIN rightside ON something,然后执行WHERE rightside.column = something,则将LEFT JOIN转换为直JOIN。

直join会抑制leftside中与联接中的ON不匹配的行。

所以试着摆脱你的WHERE条件。

编辑我不知道你提到的框架。

但是,为了得到每一个有特定标签的商品,你可以这样做。

      SELECT DISTINCT itemid FROM taglist WHERE tagid = $tags

然后你可以用进行主查询

    WHERE items.id IN (SELECT DISTINCT itemid FROM taglist WHERE tagid = $tags)

只筛选出具有匹配标签的项目。您的主查询将获取所有标签,包括带有tagid = $tags的标签和所有其他标签,但仅针对具有匹配标签的项目。它的核心都是理论。