MySQL内外连接查询分为:交叉连接、相等连接、自然连接,右连接,左连接

一,内连接查询分为:交叉连接、相等连接、自然连接。
1.交叉连接又称为“笛卡尔连接”或“叉乘”,它是所有类型的内连接的基础

语法:SELECT *FROM 表名1 CROSS JOIN 表名2 等价于:SELECT *FROM 表名1,表名2。
注意:连接依据的列可能包含null值,null值不与任何值匹配(甚至和他本身)。
2.相等连接

语法:SELECT *FROM 表名1 JOIN 表名2 ON 表名1.字段名=表名2.字段名。
3.自然连接
自然连接是一种特殊的连接,它要求相连接的两个表的连接依据列必须是相同的字段(字段名相同,字段属性相同)。

注意:部分数据库不支持自然连接,如SQL server。
语法:SELECT *FROM 表名1 NATVRAL JOIN 表名2。

1.内连接的定义是什么?有哪几种类型的内连接?

内连接基于连接谓词,它将两张表(如A和B)的列组合在一起,产生新的结果表。具体过程是将A表的每一行和B表的每一行进行比较, 并找出满足连接谓词的组合,当连接谓词被满足,A和B中匹配的行会按列组合(并排组合)成结果集中的一行。

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

二,①查询表中所有数据:
select * from 表名
②查询某几个字段:
select 字段名,字段名,字段名 from 表名select 字段名( sname as 姓名),字段名( sbirthday as 出生日期) from 表名
③带条件的查询:
select * from 表名 where 条件( sname!=’小红’)
select 字段名 from 表名 where 条件
④多条件查询:
select * from 表名 where 条件 逻辑运算符(AND,OR,NOT, XOR) 另一个条件
select * from teacher where depart=‘电工系’ OR depart=‘计算机系’ and tsex=‘男’
⑤查询表中字段不为空:
select * from 表名 where 字段名 is not null
⑥排序:
select * from 表名 order by 字段名 ascselect * from 表名 order by 字段名 desc
⑦多列排序:
select * from 表名 order by 字段名,第二个字段名 desc
⑧查询不重复字段列:
select DISTINCT depart from teacher

三,外连接
内连接:只显示匹配的数据
外连接:显示匹配的数据,还显示(部分或者全部)不匹配的数据,那就是显示(全部!!??)的数据
左外连接 left [outer] join 显示匹配的数据和左边表的不匹配的数据
select * from 表名1 left join 表名2 on 表名1.no=表名2.no
右外连接 right [outer] join 显示匹配的数据和右边表的不匹配的数据
select * from 表名1 right join 表名2 on 表名1.no=表名2.no
全外连接 full [outer] join 显示匹配的数据,和左、右边表的不匹配的数据。MySQL不支持全外连接,所以只能采取关键字UNION来联合左、右连接的方法

原文链接:https://blog.csdn.net/weixin_58963835/article/details/119462925

你可能感兴趣的:(数据库,sql,database)