一般为前端写 表格数据,比如 jqgrid 的时候,如果是多表查询,希望 如果其中某个表是没有数据的,
那么如果其他表有数据,就显示出来,没有数据的,就显示出来空列
比如
SELECT a.ID_, a.CRM_OU_USER_ID_, a.HR_EFF_PFMCE_PLANEECPT_ID_, a.TYPE_,
a.TITLE_,a.WORK_CONTENT_, a.GOAL_, a.WEIGHT_, a.PLAN_STIME_, a.PLAN_ETIME_, a.STATUS_, a.CREATE_TIME_,
( SELECT ps.ID_ mypsid
FROM HR_EFF_PFMCE_PSCORE ps WHERE ps.HR_EFF_PFMCE_PLANEC_ID_=a.ID_ AND ps.STATUS_='0' AND ps.BIZ_STATE_='1' )
FROM HR_EFF_PFMCE_PLANEE a
WHERE a.HR_EFF_PFMCE_PLANEECPT_ID_=110003208000028
如果 HR_EFF_PFMCE_PLANEE 表有数据, 但是 HR_EFF_PFMCE_PSCORE表查询不到数据,
那么 ps.ID_ mypsid 为空 列 。
但是这样有一个问题,就是 如果 我希望 HR_EFF_PFMCE_PSCORE 表里面的 多个列,也查询出来,
那么代码就比较多了。
可以使用 left join 查询,其他 join 查询是不可以的,HR_EFF_PFMCE_PSCORE 为null 的时候,所有的结果都是null 的,而且 AND ps.STATUS_='0' AND ps.BIZ_STATE_='1' 这些条件不 可以放入 where 条件 里面,否则查询出来的结果也是 所有列都是 null 的
SELECT a.ID_, a.CRM_OU_USER_ID_, a.HR_EFF_PFMCE_PLANEECPT_ID_, a.TYPE_,
a.TITLE_,a.WORK_CONTENT_, a.GOAL_, a.WEIGHT_, a.PLAN_STIME_, a.PLAN_ETIME_, a.STATUS_, a.CREATE_TIME_,
ps.ID_ mypsid, ps.SCORE_
FROM HR_EFF_PFMCE_PLANEE a
left JOIN HR_EFF_PFMCE_PSCORE ps
ON ps.HR_EFF_PFMCE_PLANEC_ID_=a.ID_ AND ps.STATUS_='0' AND ps.BIZ_STATE_='1'
WHERE a.HR_EFF_PFMCE_PLANEECPT_ID_=110003208000028
同理多张表,就多个 left join
SELECT a.ID_, a.CRM_OU_USER_ID_, a.HR_EFF_PFMCE_PLANEECPT_ID_, a.TYPE_,
a.TITLE_,a.WORK_CONTENT_, a.GOAL_, a.WEIGHT_, a.PLAN_STIME_, a.PLAN_ETIME_, a.STATUS_, a.CREATE_TIME_,
ps.ID_ mypsid, ps.SCORE_ myscore , ps.DESCRIBE_ mydescribe ,
psleader.ID_ leadpsid , psleader.SCORE_ leadscore , psleader.DESCRIBE_ leaderdescribe
FROM HR_EFF_PFMCE_PLANEE a
left JOIN HR_EFF_PFMCE_PSCORE ps
ON ps.HR_EFF_PFMCE_PLANEC_ID_=a.ID_ AND ps.STATUS_='0' AND ps.BIZ_STATE_='1'
left JOIN HR_EFF_PFMCE_PSCORE psleader
ON psleader.HR_EFF_PFMCE_PLANEC_ID_=a.ID_ AND psleader.STATUS_='0' AND psleader.BIZ_STATE_='1'
WHERE a.HR_EFF_PFMCE_PLANEECPT_ID_=110003208000028
这里给出来 left join 和 right join 的区别
下面是例子分析
表A记录如下:
aID aNum
1 a20050111
2 a20050112
3 a20050113
4 a20050114
5 a20050115
表B记录如下:
bID bName
1 2006032401
2 2006032402
3 2006032403
4 2006032404
8 2006032408
创建这两个表SQL语句如下:
CREATE TABLE a
aID int( 1 ) AUTO_INCREMENT PRIMARY KEY ,
aNum char( 20 )
)
CREATE TABLE b(
bID int( 1 ) NOT NULL AUTO_INCREMENT PRIMARY KEY ,
bName char( 20 )
)
INSERT INTO a
VALUES ( 1, 'a20050111' ) , ( 2, 'a20050112' ) , ( 3, 'a20050113' ) , ( 4, 'a20050114' ) , ( 5, 'a20050115' ) ;
INSERT INTO b
VALUES ( 1, ' 2006032401' ) , ( 2, '2006032402' ) , ( 3, '2006032403' ) , ( 4, '2006032404' ) , ( 8, '2006032408' ) ;
实验如下:
1.left join(左联接)
sql语句如下:
SELECT * FROM a
LEFT JOIN b
ON a.aID =b.bID
结果如下:
aID aNum bID bName
1 a20050111 1 2006032401
2 a20050112 2 2006032402
3 a20050113 3 2006032403
4 a20050114 4 2006032404
5 a20050115 NULL NULL
(所影响的行数为 5 行)
结果说明:
left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的.
换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录(例子中为: A.aID = B.bID).
B表记录不足的地方均为NULL.
2.right join(右联接)
sql语句如下:
SELECT * FROM a
RIGHT JOING b
ON a.aID = b.bID
结果如下:
aID aNum bID bName
1 a20050111 1 2006032401
2 a20050112 2 2006032402
3 a20050113 3 2006032403
4 a20050114 4 2006032404
NULL NULL 8 2006032408
(所影响的行数为 5 行)
结果说明:
仔细观察一下,就会发现,和left join的结果刚好相反,这次是以右表(B)为基础的,A表不足的地方用NULL填充.
3.inner join(相等联接或内联接)
sql语句如下:
SELECT * FROM a
INNER JOIN b
ON a.aID =b.bID
等同于以下SQL句:
SELECT *
FROM a,b
WHERE a.aID = b.bID
结果如下:
aID aNum bID bName
1 a20050111 1 2006032401
2 a20050112 2 2006032402
3 a20050113 3 2006032403
4 a20050114 4 2006032404
结果说明:
很明显,这里只显示出了 A.aID = B.bID的记录.这说明inner join并不以谁为基础,它只显示符合条件的记录.
LEFT JOIN操作用于在任何的 FROM 子句中,
组合来源表的记录。使用 LEFT JOIN 运算来创建一个左边外部联接。左边外部联接将包含了从第一个(左边)开始的两个表中的全部记录,即
使在第二个(右边)表中并没有相符值的记录。