SQL三表关联查询 30
作者表:作者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
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 = '给定用户名'
INNER JOIN 作品表 b on a.作品ID=b.作品ID
INNER JOIN 作者表 c on c.作者ID=b.作者ID
where a.用户名=参数
你的用户表下没与作者表或作品表有关系的列,所以没办法连在一块查的,就算连在一块查也是没意义的。
除非你的用户表下再加一个作品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’;