一个mysql多表查询的问题

WBOY
Freigeben: 2016-06-06 20:46:09
Original
878 Leute haben es durchsucht

求问一个数据库问题。 user表有一个real_name字段,表示用户姓名。plag表有两个字段 user_id1, user_id2, 现在要查询plag表中的所有信息,同时把user_id1, user_id2对应user表中的real_name也输出出来。怎么写sql?

比如: user表用两条记录:
id: 1 real_name: Tom
id: 2 real_name: Mike

plag表有这样一条记录
id: 1 user_id1: 1 user_id2: 2

我希望能把plag以这样的形式输出:
id: 1 name1: Tom name2: Mike

求大神给出sql并解释

回复内容:

求问一个数据库问题。 user表有一个real_name字段,表示用户姓名。plag表有两个字段 user_id1, user_id2, 现在要查询plag表中的所有信息,同时把user_id1, user_id2对应user表中的real_name也输出出来。怎么写sql?

比如: user表用两条记录:
id: 1 real_name: Tom
id: 2 real_name: Mike

plag表有这样一条记录
id: 1 user_id1: 1 user_id2: 2

我希望能把plag以这样的形式输出:
id: 1 name1: Tom name2: Mike

求大神给出sql并解释

<code>select plag.id, group_concat(user.name order by user.id) as real_names from plag left join user on plag.user_id1 = user.id or plag.user_id2 = user.id 
</code>
Nach dem Login kopieren

这句虽然输出有点出入,但是应该也符合题主的需求,输出结果应该为:

<code>id | realnames
1 | Tom,Mike 
</code>
Nach dem Login kopieren

得到的 realnames 是以 user.id 按序排列的,结果集是可操作的。
下面这句可以得到楼主希望的输出:

<code>select plag.id,(select user.name from plag inner join user on user.id = plag.user_id1) as name1, (select user.name from plag inner join user on user.id = plag.user_id2) as name2 from plag
</code>
Nach dem Login kopieren

输出应该为:

<code>id | name1 | name2
1 | Tom | Mike
</code>
Nach dem Login kopieren

应该使用 INNER JOIN 方式吧

参考 http://www.w3school.com.cn/sql/sql_join_inner.asp

<code>select p.id, u1.real_name as name1, u2.real_name as name2
from plag p, user as u1, user as u2
where p.user_id1 = u1.id and p.user_id2 = u2.id;
</code>
Nach dem Login kopieren
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!