本文章来给各位朋友介绍PHP MySQL多表联合查询sql语句总结,有需要了解的同学可参考.
最简的一种联合查询,代码如下:
SELECT * FROM table1 n, table2 i WHERE n.itemid = i.itemid
例:
推广地点表promotion_addr字段:name,id
电话报竣表unicom_record字段:date, sheet_id(关联sheet表id)
报单表sheet字段:id,promotion_addr_id(关联promotion_addr表id)
要求统计某个月已报竣各推广地点的推广个数,代码如下:
- SELECT
- p.name,count(*)
- FROM
- unicom_recordASur
- LeftJoinsheetASsONur.sheet_id=s.id
- LeftJoinpromotion_addrASpONs.promotion_addr_id=p.id
- WHERE
- ur.status=?‘COMPLETE’AND
- ur.`date`>=?’2010-03-01′AND
- ur.`date`<?’2010-04-01′
- GROUPBY
- p.id
或使用between and语句.
内连接INNER JOIN,代码如下:
join_table: table_reference [INNER | CROSS] JOIN table_factor [join_condition]
MySQL中的外连接,代码如下:
select id, name, action from user as u left join user_action a on u.id = a.user_id
还是先 Create table 吧,代码如下:
- createtableemp(
- idintnotnullprimarykey,
- namevarchar(10)
- );
- createtableemp_dept(
- dept_idvarchar(4)notnull,
- emp_idintnotnull,
- emp_namevarchar(10),
- primarykey(dept_id,emp_id));
- insertintoemp()values
- (1,”Dennis-1″),
- (2,”Dennis-2″),
- (3,”Dennis-3″),
- (4,”Dennis-4″),
- (5,”Dennis-5″),
- (6,”Dennis-6″),
- (7,”Dennis-7″),
- (8,”Dennis-8″),
- (9,”Dennis-9″),
- (10,”Dennis-10″);
- insertintoemp_dept()values
- (“R&D”,1,”Dennis-1″),
- (“DEv”,2,”Dennis-2″),
- (“R&D”,3,”Dennis-3″),
- (“Test”,4,”Dennis-4″),
- (“Test”,5,”Dennis-5″);
- >>leftjoin
- ————-
代码如下:
select a.id,a.name,b.dept_id from emp a left join emp_dept b on (a.id=b.emp_id);
挑出左边的 table emp 中的所有资料,即使 emp_dept 中没有的资料也挑出来,没有的就用 NULL来显示,也即显示资料是以左边的 table emp 中的资料为基础,代码如下:
- mysql>selecta.id,a.name,b.dept_id
- ->fromempaleftjoinemp_deptbon(a.id=b.emp_id);
- +—-+———–+———+
- |id|name|dept_id|
- +—-+———–+———+
- |1|Dennis-1|R&D|
- |2|Dennis-2|DEv|
- |3|Dennis-3|R&D|
- |4|Dennis-4|Test|
- |5|Dennis-5|Test|
- |6|Dennis-6|NULL|
- |7|Dennis-7|NULL|
- |8|Dennis-8|NULL|
- |9|Dennis-9|NULL|
- |10|Dennis-10|NULL|
- +—-+———–+———+
挑出 table emp 中有而 table emp_dept 中没有的人员资料,代码如下:
- selecta.id,a.name,b.dept_id
- fromempaleftjoinemp_deptbon(a.id=b.emp_id)
- whereb.dept_idISNULL;
- mysql>selecta.id,a.name,b.dept_id
- ->fromempaleftjoinemp_deptbon(a.id=b.emp_id)
- ->whereb.dept_idISNULL;
- +—-+———–+———+
- |id|name|dept_id|
- +—-+———–+———+
- |6|Dennis-6|NULL|
- |7|Dennis-7|NULL|
- |8|Dennis-8|NULL|
- |9|Dennis-9|NULL|
- |10|Dennis-10|NULL|
- +—-+———–+———+
把 table emp_dept 放在左边的情形(当然以 emp_dept 中的数据为基础来显示资料,emp 中比emp_dept 中多的资料也就不会显示出来了),代码如下:
- selecta.id,a.name,b.dept_id
- fromemp_deptbleftjoinempaon(a.id=b.emp_id);
- mysql>selecta.id,a.name,b.dept_id
- ->fromemp_deptbleftjoinempaon(a.id=b.emp_id);
- +——+———-+———+--phpfensi.com
- |id|name|dept_id|
- +——+———-+———+
- |2|Dennis-2|DEv|
- |1|Dennis-1|R&D|
- |3|Dennis-3|R&D|
- |4|Dennis-4|Test|
- |5|Dennis-5|Test|
- +——+———-+———+
- >>rightjoin
- —————
代码如下:
select a.id,a.name,b.dept_id from emp a right join emp_dept b on (a.id=b.emp_id);
挑资料时以右边 table emp_dept 中的资料为基础来显示资料,代码如下:
- mysql>selecta.id,a.name,b.dept_id
- ->fromemparightjoinemp_deptbon(a.id=b.emp_id);
- +——+———-+———+
- |id|name|dept_id|
- +——+———-+———+
- |2|Dennis-2|DEv|
- |1|Dennis-1|R&D|
- |3|Dennis-3|R&D|
- |4|Dennis-4|Test|
- |5|Dennis-5|Test|
- +——+———-+———+
- 5rowsinset(0.00sec)
我们再把 table 的位置交换一下,再用 right join 试试,代码如下:
- selecta.id,a.name,b.dept_id
- fromemp_deptbrightjoinempaon(a.id=b.emp_id);
- mysql>selecta.id,a.name,b.dept_id
- ->fromemp_deptbrightjoinempaon(a.id=b.emp_id);
- +—-+———–+———+
- |id|name|dept_id|
- +—-+———–+———+
- |1|Dennis-1|R&D|
- |2|Dennis-2|DEv|
- |3|Dennis-3|R&D|
- |4|Dennis-4|Test|
- |5|Dennis-5|Test|
- |6|Dennis-6|NULL|
- |7|Dennis-7|NULL|
- |8|Dennis-8|NULL|
- |9|Dennis-9|NULL|
- |10|Dennis-10|NULL|
- +—-+———–+———+
是不是和 left join 一样了?
>> direct join
如果用right join 同不用 Join 直接挑资料是相同的,它等介於以下的指令,代码如下:
- selecta.id,a.name,b.dept_id
- fromempa,emp_deptb
- wherea.id=b.emp_id;
- mysql>selecta.id,a.name,b.dept_id
- ->fromempa,emp_deptb
- ->wherea.id=b.emp_id;
- +—-+———-+———+
- |id|name|dept_id|
- +—-+———-+———+
- |2|Dennis-2|DEv|
- |1|Dennis-1|R&D|
- |3|Dennis-3|R&D|
- |4|Dennis-4|Test|
- |5|Dennis-5|Test|
- +—-+———-+———+
怎样,弄明白了吗?Enjoy it!