我有以下的数据库表和列:MySQL查询为什么我的INNER JOIN组最新结果
students
+------------+-------------------+------------------+
| student_id | student_firstname | student_lastname |
+------------+-------------------+------------------+
| 95 | John | Doe |
+------------+-------------------+------------------+
studentcourseplan
+--------+------------+
| cpl_id | student_id |
+--------+------------+
| 209 | 95 |
| 273 | 95 |
+--------+------------+
studentdates
+------------+-------------------+-----------------+
| student_id | student_startdate | student_enddate |
+------------+-------------------+-----------------+
| 95 | 2012-07-02 | 2012-08-17 |
| 95 | 2012-08-20 | 2012-11-16 |
+------------+-------------------+-----------------+
如果我运行此查询...
SELECT
scp.cpl_id,
s.student_id,
s.student_firstname,
s.student_lastname,
sd.student_startdate,
sd.student_enddate
FROM
studentcourseplan scp
INNER JOIN
students s ON s.student_id = scp.student_id
INNER JOIN
studentdates sd ON sd.student_id = s.student_id
...我得到的下面的输出:
+--------+------------+-------------------+------------------+-------------------+-----------------+
| cpl_id | student_id | student_firstname | student_lastname | student_startdate | student_enddate |
+--------+------------+-------------------+------------------+-------------------+-----------------+
| 209 | 95 | John | Doe | 2012-07-02 | 2012-08-17 |
| 273 | 95 | John | Doe | 2012-07-02 | 2012-08-17 |
+--------+------------+-------------------+------------------+-------------------+-----------------+
通知从结果的日期相比较,以在表中studentdates
的值。他们错了。我想要类似下面的输出:
+--------+------------+-------------------+------------------+-------------------+-----------------+
| cpl_id | student_id | student_firstname | student_lastname | student_startdate | student_enddate |
+--------+------------+-------------------+------------------+-------------------+-----------------+
| 209 | 95 | John | Doe | 2012-07-02 | 2012-08-17 |
| 273 | 95 | John | Doe | 2012-08-20 | 2012-11-16 |
+--------+------------+-------------------+------------------+-------------------+-----------------+
我在做什么错?
请检查你的关于你的数据库模式的问题,因为就目前而言,你想在你的查询中实现的关系看起来不对。 –
你是什么意思? – David
你怎么知道'cpl_id 209'属于'start_date'2012-07-02''而不是'2012-08-20'? –