MySQL第七章:连接查询可分为内连接和外连接。

本文介绍了SQL中的内连接、自然连接和外连接的语法,并给出了多表连接的实际查询示例,包括查询非空调车信息和公交二公司司机信息。同时,展示了如何从数据库中获取非空调车的车牌号、型号、线路信息以及公交线路的起点和终点站。
摘要由CSDN通过智能技术生成

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 = '非空调车';

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值