Mysql在一张表查出记录后,在另一张表里关联的某个字段替换其中两个字段

博客介绍了一个SQL应用场景,给定两张表,要查询id为1的记录的创建用户名和更改用户名。因表一查出id后只能得到ID号,需到表二根据ID将对应字段替换成用户名,思路是用两次left join,一个字段替换JOIN查一次,两个替换就查两次。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

应用场景:给定两张表,查询id为1的记录的创建用户名和更改用户名。
表1:

ID创建用户ID更改用户ID电子黑板
1adminteacher电子板一
2adminstudent电子板二
3adminteacher电子板三

表2(用户表):

ID用户名
admin张三
teacher李四
student王小二

这里在表一查出id为1之后拿到的只是ID号,并不能获得具体名字,需要到表二中,将对应两个字段根据ID查询替换成用户名。为了方便理解,表头全用中文替代。思路为用两次left join。
查询语句如下:

SELECT T2.用户名 AS 创建用户ID,
       T3.用户名AS 更改用户ID,
       T1.电子黑板
FROM TAB_1 AS T1
LEFT JOIN TAB_2 AS T2
    ON T1.创建用户ID=T2.ID
LEFT JOIN TAB_2 AS T3
    ON T1.更改用户ID=T3.ID
WHERE T1.ID=1

总结:一个字段需要替换JOIN查一次,两个字段需要替换就JOIN查两次,对表2取别名T2,T3即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值