SQL - 如何取出链式数据?

Posted

技术标签:

【中文标题】SQL - 如何取出链式数据?【英文标题】:SQL - how to get out chained data? 【发布时间】:2012-11-01 16:13:11 【问题描述】:

我有 4 个为我自动生成的表:

用户 挑战 锻炼 Challenge_Exercise

一个用户可能有很多挑战,一个挑战会有很多练习。

我注意到挑战表引用了它的父用户(称为 user_id),但练习表中没有对挑战的引用;他们的关系作为 Challenge_id 和 exercise_id 存储在 Challenge_Exercise 中。

我的问题是,我将如何取出每个与特定用户相关联的练习?例如 id = 1 的用户?

【问题讨论】:

@Laurence,我已经这样做了,但我不明白这些例子。没有与我的问题相似的示例。 【参考方案1】:
SELECT *
FROM   excerise,
       challenge_excerise,
       challenge
WHERE  challenge.user_id = 1
       AND challenge_excerise.challenge_id = challenge.id
       AND challenge_excerise.exercise_id = excercise.id

我在这里做的是join,您也可以明确地使用inner joins 来做(如果您想了解更多信息,请在谷歌上搜索)。

需要此表是因为您有many to many 关系,这意味着每个挑战可以有多个练习,但每个练习也可以有多个挑战。那就做一个额外的表是一个标准,所以你没有多余的数据,这个表通常被称为junction table

如果你想了解背景,只需 google 一下,这个主题有大量数据。

【讨论】:

请查看 ANSI 样式的连接,它们更容易阅读!值得一读:sqlblog.com/blogs/aaron_bertrand/archive/2009/10/08/… 我知道这些连接,我的意思是“明确地这样做”。就我个人而言,我不觉得它们更容易阅读。

以上是关于SQL - 如何取出链式数据?的主要内容,如果未能解决你的问题,请参考以下文章

SQL 如何取出数据库中一列的所有值.....

如何实现从数据库中取出所有日期,使用SQL语句能够区分出每年的日期。

sql如何根据时间取出最新的数据记录

如何用SQL语句取出数据库中的特定一条数据?

如何使用SQL取出某字段第二大的记录

如何用php取出数据库表中一列所有数据?