如何在 MySQL 中多次连接同一个表
当您需要在一个表中多次关联同一个表中的记录时查询时,MySQL 提供了将表与其自身连接的能力。这允许您从同一表的不同行检索数据,从而有效地在行之间创建新的关系。
为了说明这个概念,请考虑以下场景:
您有两个表: “域名”和“评论”。 “domains”表存储域 ID 和域名,而“reviews”表包含发件人 (rev_dom_from) 和收件人 (rev_dom_for) 的评论数据和引用域名。
您的任务是显示两者网页上的域名。虽然您可以使用标准 LEFT JOIN 轻松显示一个域名,但出现了问题:如何从“rev_dom_from”列中检索第二个域名?
解决方案在于利用多个联接。通过多次加入“domains”表,可以在评论和对应的域名之间建立不同的关系:
SELECT toD.dom_url AS ToURL, fromD.dom_url AS FromUrl, rvw.* FROM reviews AS rvw LEFT JOIN domain AS toD ON toD.Dom_ID = rvw.rev_dom_for LEFT JOIN domain AS fromD ON fromD.Dom_ID = rvw.rev_dom_from
在此查询中:
通过为连接表添加别名,您可以区分两个实例并检索所需的数据。这种多次连接同一个表的技术通常称为“自连接”,可以应用于需要在单个表中建立多个关系的各种场景。
以上是如何在 MySQL 中自连接表以检索多行数据?的详细内容。更多信息请关注PHP中文网其他相关文章!