SQL三表关联查询

三个数据表,分别是 用户表:用户id,用户名,等级
作者表:作者ID,作者QQ,作者电话
作品表:作品ID,作品名字,出版社
想达到的效果是:列出给定用户名的图书情况
用户名,图书名 作者 出版社
三个数据表,分别是 用户表:用户id,用户名,等级,作品ID
作者表:作者ID,作者名,作者QQ,作者电话
作品表:作品ID,作品名字,作者id,出版社
想达到的效果是:列出给定用户名的图书情况
用户名,作品名字 作者 出版社

这回有关系了,谢谢帮忙

select a.*,c.f from (select * from a inner join b on a.a = b.a) as a inner join c on a.d = c.d

select a.*,c.f from a inner join b on a.a = b.a inner join b.d = b.d

两个都可以,第一个更容易理解,括号里的部分是查询出查询表A的数据和当表A的a=表B的a的数据,把这个结果集,再inner join c on a.d = c.d

查询出表B的d=表C的d 所对应的f的值。

扩展资料:

三个表左连接的sql语句

select

intro_web_page.id,

web_id,

web_name,

template_id ,

template_name,

template_param,

intro_web_page.sort_order 

from intro_web_page left join intro_web on (web_id=intro_web.id) 

left join intro_template on (intro_web_page.template_id=intro_template.id)

注:这里主要是看,当两个表和某一个表都有联系的时候,左连接left join    on要怎么写。

更新语句

UPDATE issue INNER JOIN user ON `issue`.insert_uid and `user`.id INNER JOIN 

(SELECT  issue.id as id,issue.insert_uid as uid,`user`.school_id as school_id,school.area as area1 from issue,user,school 

where issue.insert_uid=`user`.id and  `user`.school_id=school.id) AS T1

ON issue.insert_uid=T1.uid

SET issue.area=T1.area1

温馨提示:答案为网友推荐,仅供参考
第1个回答  2012-06-05
看不出来你的表之间的关系

SELECT a.用户名, c.作品名字,c.作者名, c.出版社
FROM 用户表 a, 作者表 b, 作品表 c
WHERE a.作品ID = c.作品ID
AND c.作者id = b.作者id
AND 用户id = '给定用户名'追问

麻烦再给看看呗

追答

SELECT a.用户名, c.作品名字,b.作者名, c.出版社
FROM 用户表 a, 作者表 b, 作品表 c
WHERE a.作品ID = c.作品ID
AND c.作者id = b.作者id
AND 用户id = '给定用户名'

追问

没出来,数据库是ACCESS,并且作品对作者是多对一的关系,不知是什么问题

追答

AND a.用户id = '给定用户名'

修改为你的id没有?

SELECT a.用户名, c.作品名字,b.作者名, c.出版社
FROM 用户表 a, 作者表 b, 作品表 c
WHERE a.作品ID = c.作品ID
AND c.作者id = b.作者id
AND a.用户id = 'xxx'

第2个回答  推荐于2018-03-08
select a.用户名,b.作品名字,c.作者,b.出版社 from 用户表 a
INNER JOIN 作品表 b on a.作品ID=b.作品ID
INNER JOIN 作者表 c on c.作者ID=b.作者ID
where a.用户名=参数本回答被网友采纳
第3个回答  推荐于2018-08-04
关系型数据库中,每个表之间必需有一个或多个列与其它的表有关系(如相等),才能把两个表合在一起查询。
你的用户表下没与作者表或作品表有关系的列,所以没办法连在一块查的,就算连在一块查也是没意义的。

除非你的用户表下再加一个作品ID,这样就可以关连起来查询了

SELECT a.用户名,c.作品名字,b.作者名,c.出版社,
FROM 用户表 as a
JOIN 作品表 as c ON a.作品ID = c.作品ID
JOIN 作者表 as b ON c.作者ID = b.作者ID
WHERE a.用户名 = ‘XXX’;本回答被网友采纳
第4个回答  2012-06-05
用户表和下面的两个表半毛钱关系都没有,怎么查??
相似回答