连接查询 两张表里有同名字段的问题
2016-03-04 19:16
267 查看
左连接查询在开发中很常用,但有个问题常常会遇到,两个表中有同名字段时,比如左右表都有一个id字段,会造成查询结果中左表的id值被右表的id值覆盖掉(大部分php框架都是这个效果),而且还不会报错,容易留下隐蔽的bug!
解决办法很简单,给同名字段用A
左连接查询在开发中很常用,但有个问题常常会遇到,两个表中有同名字段时,比如左右表都有一个id字段,会造成查询结果中左表的id值被右表的id值覆盖掉(大部分php框架都是这个效果),而且还不会报错,容易留下隐蔽的bug!
解决办法很简单,给同名字段用AS起别名。例如:order表,farmer表都含有id字段,
这样不需要把每个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
解决办法很简单,给同名字段用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
相关文章推荐
- SQL中的三值逻辑
- SQL Server 作业批量停止
- 结束SQL阻塞的进程
- 动态生成SQL Server视图作业
- SQL Server 语句操纵数据库
- SQL(结构化查询语句)
- oracle sql日期比较
- linux快速部署mysql服务器
- sql 存储过程分页
- 在WINXP系统上安装SQL Server企业版的方法
- 通过批处理调用SQL的方法(osql)
- SQL Server 存储过程的分页
- ASP程序与SQL存储过程结合使用详解
- SQL SERVER编写存储过程小工具
- 防御SQL注入攻击时需要注意的一个问题
- PostgreSQL教程(十九):SQL语言函数
- SQL Server复制需要有实际的服务器名称才能连接到服务器
- SQL Server 2000向SQL Server 2008 R2推送数据图文教程