SQL连接
⼀、SQL 连接(JOIN)
INNER JOIN:如果表中有⾄少⼀个匹配,则返回⾏
LEFT JOIN:即使右表中没有匹配,也从左表返回所有的⾏
RIGHT JOIN:即使左表中没有匹配,也从右表返回所有的⾏
FULL JOIN:只要其中⼀个表中存在匹配,则返回⾏
⼆、SQL INNER JOIN 关键字(内连接)
2.1 等值连接:在连接条件中使⽤等于号(=)运算符⽐较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列。
2.2.不等值连接:在连接条件使⽤除等于运算符以外的其它⽐较运算符⽐较被连接的列的列值。这些运算符包括>、>=、<=、<、!>、!<;和<>。
2.3.⾃然连接:在连接条件中使⽤等于(=)运算符⽐较被连接列的列值,但它使⽤选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。
内连接:内连接查询操作列出与连接条件匹配的数据⾏,它使⽤⽐较运算符⽐较被连接列的列值。
2.2 SQL INNER JOIN 语法
SELECT column_name(s)列名
FROM table1表名
INNER JOIN table2
lumn_lumn_name主键;
例⼦:
.
select*from book as a inner join stu as b on a.sutid = b.stuid
sql left join 多表连接外连接:
3.1左联接:是以左表为基准,将a.stuid = b.stuid的数据进⾏连接,然后将左表没有的对应项显⽰,右表的列为NULL
select*from book as a left join stu as b on a.sutid = b.stuid
3.2 右连接:是以右表为基准,将a.stuid = b.stuid的数据进⾏连接,然以将右表没有的对应项显⽰,左表的列为NULL
select*from book as a right join stu as b on a.sutid = b.stuid
3.3 全连接:完整外部联接返回左表和右表中的所有⾏。当某⾏在另⼀个表中没有匹配⾏时,则另⼀个表的选择列表列包含空值。如果表之间有匹配⾏,则整个结果集⾏包含基表的数据值。
select*from book as a full outer join stu as b on a.sutid = b.stuid
3.4 交叉连接:交叉联接返回左表中的所有⾏,左表中的每⼀⾏与右表中的所有⾏组合。交叉联接也称作笛卡尔积。
select*from book as a cross join stu as b order by a.id
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论