mysql一个表中多个字段对应另一个表的id如何查询?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql一个表中多个字段对应另一个表的id如何查询?相关的知识,希望对你有一定的参考价值。

比如有如下2个表 a 和b
a
aID b1ID b2ID b3ID
1 1 3 5

2 2 4 6
b
bID bCon
1 苹果
2 香蕉
3 国内
4 国外
5 出口
6 进口
其中a表中的b1ID,b2ID,b3ID都对应b表的bID

现在要查询a表的第一条数据,期望查询到的结果如下
aID b1ID b1Con b2ID b2Con b3ID b3Con
1 1 苹果 3 国内 5 出口

请问具体sql语句该怎么写?

SELECT m.aid,m.b1id,n.bcon,m.b2id as b2id,o.bcon as b2con, m.b3id as b3id,p.bcon as b3con FROM `test` as m INNER JOIN test1 as n on m.b1id=n.bid INNER JOIN test1 as o on m.b2id=o.bid INNER JOIN test1 as p on m.b3id=p.bid;

结果:

参考技术A select n.aid, m.bid ,m.bcon , l.bid,l.bcon,o.bid ,o.bcon from
a n join b m on n.b1id=m.bid
join b l on n.b2id=l.bid
join b o on n.b3id=o.bid

以上是关于mysql一个表中多个字段对应另一个表的id如何查询?的主要内容,如果未能解决你的问题,请参考以下文章

mysql如何更新一个表中的某个字段值等于另一个表的某个字段值

[转]mysql 从一个表中查数据并插入另一个表实现方法

Mysql数据库一个表字段中存了id,并以逗号分隔,id对应的详细信息在另一个表中

MySQL 更新一个表里的字段等于另一个表某字段的值

mysql同一张表中两个字段 关联另一张表的相同字段 查询出两个值

mysql外键