您好,欢迎访问代理记账网站
  • 价格透明
  • 信息保密
  • 进度掌控
  • 售后无忧

2021.6.1

链接查询

连接查询可分为内连接和外连接。

一.内连接:内连接分3种:交叉连接、相等连接、自然连接。

1.内连接语法:

1.交叉连接:

交叉链接又称“笛卡尔链接”,即所有类型的内连接的基础
语法

select *
from table1
join table2
1
2
3
等价于

select *
from table1,table2
1
2
2.内连接语法(牢记):

select freldlist 查询目标 
from table1 表名
[inner] join table2 链接的表名 
on table1.colunm1=table2.colunm2 列名
[where condition] 条件
1
2
3
4
5
3.自然连接(牢记):

自然连接中列必须是相同字段名才能连接。
自然连接中能把重复的列去掉,而普通的内连接不能。

语法

select freldlist 
from table1 
natural join table2 
[where condition]
1
2
3
4
##多表连接:
多表连接是通过两两相连的方式建立查询。
语法:

select freldlist 
from table1 
 join table2 
on table1.colunm1=table2.colunm2_1
 join table3 
on table2.colunm2_2=table3.colunm3
[where condition]
1
2
3
4
5
6
7
三.外连接:
外连接中不完全相同的表数据记录也能出现在结果集中。
外连接分为左外连接和右外连接。

语法

select 字段名
from 表名1
left|right|full [outer]
 join 表名2
 on 表名1.字段名1=表名2.字段名2
1
2
3
4
5
作业示例:

一.查询bus数据库:

1.获取所有非空调车的车牌号、型号和司机姓名、所属线路的线路号、起点站和终点站信息;

代码

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 = '非空调车';
    AND l.lineID = v.lineID
    AND d.driverID = v.driverID;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
运行后(ps:一定要记住把表名添加到该列的前面,不然运行可能会出错)

2.获取公交二公司所有司机信息。要求输出司机姓名、身份证、性别和电话;

代码

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 = '公交二公司';
    GROUP BY 
    司机姓名;
1
2
3
4
5
6
7
8
9
10
11
12
13
运行后(ps:一定要记住把表名添加到该列的前面,不然运行可能会出错)

3.查询所有非空调车的车牌号、型号、线路号、起点站和终点站;
代码

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 = '非空调车';
    AND l.lineID = v.lineID;
1
2
3
4
5
6
7
8
9
10
11
12
运行后(ps:一定要记住把表名添加到该列的前面,不然运行可能会出错)

4.显示所有线路及其所配车辆基本信息,并查询车辆所配司机相关信息,要求输出司机姓名、性别、电话、车牌号、型号、线路号、起点站和终点站;
代码

SELECT
    d.NAME 司机姓名,
    licenseNO 身份证,
    d.gender 性别,
    phone 电话,
    v.plateNO 车牌号,
    v.model 型号,
    l.lineNo 线路号,
    l.from_station 起点站,
    l.end_station 终点站
FROM
    vehicle v,
    driver d,
    line l
WHERE
    v.driverID = d.driverID
AND v.lineID = l.lineID
GROUP BY 司机姓名;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
运行后(ps:一定要记住把表名添加到该列的前面,不然运行可能会出错)


二.查询easyshopping数据库:

1.获取订单 ID 为 4 的订购明细信息,要求输出商品名、单价和件数。
代码

SELECT
    g.goodsName 商品名,
    g.unitPrice 单价,
    o.quantity 件数
FROM
    ordersdetail o
JOIN goods g where o.ordersID = 4
GROUP BY 商品名;
1
2
3
4
5
6
7
8
运行后(ps:一定要记住把表名添加到该列的前面,不然运行可能会出错)

2.获取客户“王传华”所下订单详细信息,要求显示客户姓名、订单 ID、下单日期、商品名、单价和件数。
代码

SELECT
    c.cName 客户姓名,
    o.ordersDate 下单日期,
    g.goodsName 商品名,
    g.unitPrice 单价,
    od.quantity 件数
FROM
    ordersdetail od,
    goods g,
    orders o,
    customer c
WHERE
    c.cName = '王传华'
AND c.customerID = o.customerID
AND o.ordersID = od.ordersID
AND od.goodsID = g.goodsID;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
运行后(ps:一定要记住把表名添加到该列的前面,不然运行可能会出错)

3.使用左接获取所有客户的基本信息以及订购信息,要求输出客户姓名、电话、订单 ID 和下单时间。
代码

SELECT
    c.cName 客户姓名,
    c.phone 电话,
    o.ordersID 订单ID,
    o.ordersDate 下单时间
FROM
     customer c
LEFT JOIN orders o on c.customerID=o.customerID;
1
2
3
4
5
6
7
8
运行后(ps:一定要记住把表名添加到该列的前面,不然运行可能会出错)

– 4. 使用右接获取所有客户的基本信息以及订购信息,要求输出客户姓名、电话、订单 ID 和下单时间。
代码

SELECT
    c.cName 客户姓名,
    c.phone 电话,
    o.ordersID 订单ID,
    o.ordersDate 下单时间
FROM
    orders o
right JOIN customer c on c.customerID=o.customerID;
1
2
3
4
5
6
7
8
运行后(ps:一定要记住把表名添加到该列的前面,不然运行可能会出错)


学习总结:

1.敲的时候总是会忘记在列前面加表名,导致总会运行出错
2.听得很认真,但是代码还是要自己下去去记,我自认为老师主要的任务是帮我们解决难题而不是帮我们去记代码,
所以学习要自己自觉,个人觉得本章学的很踏实
————————————————
版权声明:本文为CSDN博主「世辰」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_56091062/article/details/117452781


分享:

低价透明

统一报价,无隐形消费

金牌服务

一对一专属顾问7*24小时金牌服务

信息保密

个人信息安全有保障

售后无忧

服务出问题客服经理全程跟进