关于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覆盖了。

时间: 2024-10-22 10:58:32

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

JDBC远程从一个MySql数据库中的一张表里面读出数据(这个数据库需要用SSH隧道连接,大约8W条数据),然后分别插入到另一个数据库中的两张表里

package com.eeepay.lzj.db; import java.sql.Connection; import java.sql.Date; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import com.jcraft.jsch.JSch; import com.jcraft.jsc

mysql左连接右连接(查询两张表不同的数据)

left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 :right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录:inner join(等值连接) 只返回两个表中联结字段相等的行: 表A数据: 表B数据: 1.查询两张表中都有的记录: sql: SELECT a.* FROM a INNER JOIN b ON a.a_id = b.b_id; 2.查询表A中有,表B中没有的数据: sql: SELECT a.* FROM a LEFT JO

5:查询两表中的所有字段,满足性别为‘男’的记录(使用语句块)

5:查询两表中的所有字段,满足性别为'男'的记录 1.先创建表t_code_sex 2.创建表t_employee 3.编辑数据 4.执行pl/sql语句块 ---pl/sql语句块查询满足性别为男的 declare type t_employee_record_type is record( v_empid t_employee.emp_id%type, v_emp_name t_employee.emp_name%type, v_sex_name t_code_sex.name%type);

SQL Join(连接查询)

1.连接查询分为: inner join(自然连接,自连接) Left join(左连接)/Left outer join(左外连接):效果一样 Right join(右连接)/Right outer join(右外连接):效果一样 Full join(全连接)/Full outer join (全外连接) 2.大致语法如下: select a.*,b.* from table_3 as b FULL join table_2 as a on a.id=b.Mtype --左连接 select

SQL中的join连接查询

inner join(交集 ,自然连接, 简写成join) 是最普通的连接查询,相当于早期根据where条件连接的查询 outer join(并集或部分并集,左表 + 右表) left [outer] join(左表产生完全集,右表有则匹配,没有则为null) right [outer] join(右表产生完全集,左表有则匹配,没有则为null) full [outer] join(并集) cross join(笛卡尔积,左表 * 右表) 开发中基本不用

Thinkphp join 连接查询

1 public function test ( ) 2 { 3 $User = M('authlist'); 4 $rs = $User->join('wifi_shop on wifi_authlist.shopid = wifi_shop.id')->field(' 5 wifi_authlist.id, 6 wifi_authlist.shopid, 7 wifi_authlist.routeid, 8 wifi_authlist.mac, 9 wifi_authlist.over_t

查询 哪张表 有某字段

今天一个网友问我,他知道字段名,但想知道有哪些表中有这些字段,以便他方便工作,想了一下,写了一个存储过程给他用,我想可能还有网友遇到过这个情况,所以贴出来给大家参考. 1 create proc usp_colum_search 2 @column_name varchar(300) --字段名 3 4 as 5 /* 6 作者:lcl 7 日期:2015-07-14 8 调用:exec usp_colum_search 'KSDM' 9 说明:查询哪些表中有该列 10 */ 11 12 13

三张表关联 修改第三张表所关联前两张表的某个字段的值

---三张表关联 利用关联的字段 表一关联表二 表二关联表三 来修改表三对应字段下的某个值. update GY_FYJY set zfbl='50' where fyxh in (select fyxh from gy_ylsf where fygb ='26')

查询一张表中有重复字段的记录

语法:select * from 表名 where (字段名) in  (select 字段,名 from 表名 group by 字段名 having count(*) > 1); 如一下goods表: : 执行sql语句:select * from  goods where inventory in (select inventory from goods group by inventory having count(*) > 1);