数据库语言—多表查询

 select * from 表名1,表名2;                //有时会出现无效信息,原因是结果以笛卡尔积的形式呈现

笛卡尔积:有A,B两集合,A和B的笛卡尔积就是所有组合情况。

比如:A集合有3组数据,B集合有2组数据,AB的笛卡尔积有6组数据。

A={0,1,3}        B={a,b}        A和B的笛卡尔积为={(0,a),(0,b),(1,a),(1,b),(3,a),(3,b)}

所以多表查询时往往会添加一些条件、

类似于 select * from 表名1,表名2 where 表名1.列名 = 表名2.列名;

所以这也形成了连接查询(连接查询又分为内连接和外连接)子查询

接下来用A,B两个集合作为例子

连接查询(内连接)

内连接查询出的数据时两个表交集的数据(即A,B的交集)

连接查询(外连接)

左外链接:A表的所有数据和AB交集部分

右外链接:B表的所有数据和AB交集部分

内连接——查询语法

select 字段列表 from 表1,表2 where 条件;                //隐式内连接

select 字段列表 from 表1 [inner] join 表2 on 条件;                //显示内连接

外连接——查询语法

select 字段列表 from 表1 left [outer] join 表2 on 条件;                 //左外连接

select 字段列表 from 表1 left [outer] join 表2 on 条件;                 //右外连接

子查询

查询中嵌套查询 且 根据查询结果的不同作用也不同:

单行单列:

select 字段列表 from 表名 where 字段名 【=,!=,>,< 等进行判断】 (子查询);

多行单列:

select 字段列表 from 表名 where 字段名 in(子查询);

多行多列

select 字段列表 from(子查询)where 条件;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值