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

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

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

另外在mybatis等框架中,同名属性会被左表覆盖。可以使用在model中添加别名属性,同时在select时使用as+别名对表中字段进行映射,从而解决问题。

例如recruit表与examination表都具有title,并且examination表具有recruit的外键fk_recruit_id在联合查询时可以这样写
select ex.title as exTitle, rt.title
from recruit rt and examination ex
where 1=1 and ex.fk_recruit_id = rt.id
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值