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 条件;