多表连接查询

如果我们查询的信息来自于多张表,则可通过两两相连的方式建立多表连接查询。

语法 

SELECT  fieldlist  FROM table1 JOIN  table2 ON table1.column1=table2.column2_1 JOIN table3 on table2.column2_2=table3.column3 【where condition】 

说明

(1)table2 与 table1 和 table3 两两相连

(2)三表以上连接查询的方法与三表连接查询的方法与三表连接查询的方法一样,均是通过两两相连的方法实现

多表连接查询应用

实例1:车牌号和型号来源于车辆表;司机姓名来源于司机表;线路号丶起点站和终点站来源于线路表,因而要连接三张表:车辆表,司机表和线路表,SQL语句如下:

select name 司机姓名 , plateNo 车牌号 ,model 型号,lineNo 线路号,from_station 起点站 ,end_station 终点站 from vehicle V join Diver D on V.driverID=D.driverID join line L on V.lineID=L.lineID where type='非空调车'

简单多表连接查询

如果在FROM子句中,直接列出所有要连接的表,然后再WHERE子句中指定连接条件,此为简单多表连接查询,它与内连接功能相同。

使用两表查询语句格式如下:

SELECT fieldlist FROM table1,table2 WHERE table1.column1= table2.column2(and 其他条件)

使用三表连接查询语法格式如下:

SELECT fieldlist FROM table1,table2,table3 WHERE table1.column1=table2.column2_1 and table2.column2_2=table3.column3(and 其他条件)

使用简单多表连接查询方法实现实例1:

SQL语句如下:

select name 司机姓名,licenseNo 身份证,gender 性别,phone 电话 from lineNo 线路号,from_station 起点站,end_station 终点站,from vehicle V ,Drive D,line L where V.driverID=D.driverID and V.lineID=L.lineID and type='非空调车'

 

1、查询每件商品的商品名和分类名

结果示例

SQL语句如下:

select goods.goodsname,type,typename from goods,type where goods.typeid=type.typeid

2、查询每个分类的分类名和有多少件商品

结果示例

SQL语句如下:

select type.typename,count(1) as '数量' from type,goods where goods.typeid=type.typeid group by typename

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值