1.内连接语法:
select freldlist
from table1
[inner] join table2
on table1.colunm1=table2.colunm2
[where condition]
2.自然连接语法:
自然连接中列必须是相同字段名才能连接。
自然连接中能把重复的列去掉,而普通的内连接不能。
select freldlist
from table1
natural join table2
[where condition]
二.多表连接:
多表连接是通过两两相连的方式建立查询。
语法:
select freldlist
from table1
join table2
on table1.colunm1=table2.colunm2_1
join table3
on table2.colunm2_2=table3.colunm3
[where condition]
———————————————
三.外连接:
外连接中不完全相同的表数据记录也能出现在结果集中。
外连接分为左外连接和右外连接。
外连接语法:
select 字段名
from 表名1
left|right|full [outer]
join 表名2
on 表名1.字段名1=表名2.字段名2
作业示例:
一.查询bus数据库
获取所有非空调车的车牌号、型号和司机姓名、所属线路的线路号、起点站和终点站信息;
SELECT
v.plateNO 车牌号,
v.model 型号,
d.NAME 司机姓名,
l.lineNo 线路号,
l.from_station 起点站,
l.end_station 终点站
FROM
line l
JOIN vehicle v ON l.lineID = v.lineID
JOIN driver d ON d.driverID = v.driverID
WHERE
v.type = '非空调车';
获取公交二公司所有司机信息。要求输出司机姓名、身份证、性别和电话;
SELECT DISTINCT NAME
司机姓名,
licenseNO 身份证,
d.gender 性别,
phone 电话
FROM
line l
JOIN vehicle v ON l.lineID = v.lineID
JOIN driver d ON d.driverID = v.driverID
WHERE
company = '公交二公司';
————————————————
版权声明:本文为CSDN博主「ZCCMMDD」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/ZCCMMDD/article/details/117458412
查询所有非空调车的车牌号、型号、线路号、起点站和终点站;
SELECT DISTINCT
v.plateNO 车牌号,
v.model 型号,
l.lineNo 线路号,
l.from_station 起点站,
l.end_station 终点站
FROM
line l
JOIN vehicle v ON l.lineID = v.lineID
WHERE
v.type = '非空调车';