本篇文章主要介绍了" sql中的left join及on、where条件关键字的区别详解",主要涉及到方面的内容,对于SqlServer感兴趣的同学可以参考一下:
LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。LEFT JOIN 关...
LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。
LEFT JOIN 关键字语法
SELECT column_name(s)
FROM table_name1
LEFT JOIN table_name2
ON table_name1.column_name=table_name2.column_name
注释:在某些数据库中, LEFT JOIN 称为 LEFT OUTER JOIN。
创建两张表并插入一些数据
create table class(
class_id int,
class_name varchar(20),
class_grade char(1)
);
insert into class values (1,'语文','A');
insert into class values (2,'数学','B');
insert into class values (3,'英语','C');
create table score(
class_id int,
stu_id varchar(20),
Score int
);
insert into score values (1,'A001',91);
insert into score values (2,'A001',95);
insert into score values (1,'A002',82);
insert into score values (2,'A002',87);
insert into score values (3,'B003',65);
查看表中的数据
mysql> select * from class;
+----------+------------+-------------+
| class_id | class_name | class_grade |
+----------+------------+-------------+
| 1 | 语文 | A |
| 2 | 数学 | B |
| 3 | 英语 | C |
+----------+------------+-------------+
3 rows in set (0.00 sec)
mysql> select * from score;
+----------+--------+-------+
| class_id | stu_id | Score |
+----------+--------+-------+
| 1 | A001 | 91 |
| 2 | A001 | 95 |
| 1 | A002 | 82 |
| 2 | A002 | 87 |
| 3 | B003 | 65 |
+----------+--------+-------+
5 rows in set (0.00 sec)
mysql>
比较下面几组查询结果
--如果你对left join足够熟悉的话,先不要看结果,是否可以直接说出下面查询的结果