关于left join连接查询 两张表里有同名字段的问题

Posted 满血复活的回来写代码

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于left join连接查询 两张表里有同名字段的问题相关的知识,希望对你有一定的参考价值。

左连接查询在开发中很常用,但有个问题常常会遇到,两个表中有同名字段时,比如左右表都有一个id字段,会造成查询结果中左表的id值被右表的id值覆盖掉(大部分php框架都是这个效果),而且还不会报错,容易留下隐蔽的bug!
解决办法很简单,给同名字段用AS起别名。例如:order表,farmer表都含有id字段,

$sql ="SELECT *,i.`id` AS sid from hr_users_identity as i left join hr_student as s on i.`user_id` = s.`user_id` ".$getWhere." order by sid DESC  limit {$limit}";

这样不需要把每个hr_users_identity 的字段都起个别名,前端显示调用sid ,而不是id,虽然id有返回,但一般会被右表 hr_student 的id覆盖了。

以上是关于关于left join连接查询 两张表里有同名字段的问题的主要内容,如果未能解决你的问题,请参考以下文章

mysql SELECT LEFT JOIN ON 查询总是超时,大侠能帮忙优化一下吗?

inner join(内连接)left join(左连接)right join(右连接)full join(全连接)区别

left joinright join和inner join

left joinright join和inner join

join,left join,inner join的区别?

mysql里查询时怎么把一张表里的上级ID显示为上级名称?