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 Left Join sheet AS s ON ur.sheet_id = s.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 吧
create table emp(
id int not null primary key,
name varchar(10)
);
create table emp_dept(
dept_id varchar(4) not null,
emp_id int not null,
emp_name varchar(10),
primary key (dept_id,emp_id));
insert into emp() 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″);
insert into emp_dept() values
(“R&D”,1,”Dennis-1″),
(“DEv”,2,”Dennis-2″),
(“R&D”,3,”Dennis-3″),
(“Test”,4,”Dennis-4″),
(“Test”,5,”Dennis-5″);
>> left join
————-
代码如下 | 复制代码 |
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> select a.id,a.name,b.dept_id -> from emp a left join emp_dept b on (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 中没有的人员资料
代码如下 | 复制代码 |
select a.id,a.name,b.dept_id mysql> select a.id,a.name,b.dept_id |
+—-+———–+———+
| 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 中多的资料也就不会显示出来了):
代码如下 | 复制代码 |
select a.id,a.name,b.dept_id from emp_dept b left join emp a on (a.id=b.emp_id); mysql> select a.id,a.name,b.dept_id -> from emp_dept b left join emp a on (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 |
+——+———-+———+
>> right join
—————
代码如下 | 复制代码 |
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> select a.id,a.name,b.dept_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 |
+——+———-+———+
5 rows in set (0.00 sec)
# 我们再把 table 的位置交换一下,再用 right join 试试
代码如下 | 复制代码 |
select a.id,a.name,b.dept_id mysql> select a.id,a.name,b.dept_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 直接挑资料是相同的,它等介於以下的指令
代码如下 | 复制代码 |
select a.id,a.name,b.dept_id mysql> select a.id,a.name,b.dept_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!
补充:数据库,mysql教程