我有一个有三个表的关系数据库。第一个containts id与第二个有关。第二个包含与第三个相关的id。第三个包含我之后的结果。mysql - 查询三个表
是否有可能使用单个查询来查询第一个表中的id,该表中给出了与第三个表有关的所有结果?
对不起,我是mySQL的新手。
我有一个有三个表的关系数据库。第一个containts id与第二个有关。第二个包含与第三个相关的id。第三个包含我之后的结果。mysql - 查询三个表
是否有可能使用单个查询来查询第一个表中的id,该表中给出了与第三个表有关的所有结果?
对不起,我是mySQL的新手。
试试这个
select * from table1 t1
join table2 t2 on t1.t2ref = t2.id
join table3 t3 on t2.t3ref = t3.id
添加where子句中的表1
where t1.field = 'value'
使用JOIN命令搜索特定的行链接你的表到oneantother。
此外,我建议由基思布朗this tutorial。
你想做一个join。关于这个和various ways有很多tutorials这样做。
是
SELECT t3.*
FROM t1, t2, t3
WHERE t1.id = t2.id
AND t2.otherid = t3.id
AND t1.id = XXXX
要使用一个连接:
SELECT `t3`.`id`
FROM `table3` `t3`
LEFT JOIN `table2` `t2`
ON `t3`.`foreign_id` = `t2`.`id`
LEFT JOIN `table1` `t1`
ON `t2`.`foreign_id` = `t1`.`id`
WHERE `t1`.`id` = 'some_id'
如果你给一个表结构,我们可以给你更具体的答案。 – CSharpAtl 2009-11-11 15:36:20