转载
SQL 多表连接查询分为:内连接,外连接,交叉连接
内连接的使用 根据表中共同的列进行匹配,特别是存在主外键关系。
一般用的比较多
外连接 分为 左外连接,右外连接,完整连接
交叉连接返回的记录是两张表相乘的记录数
内连接主要一主表的信息为主 如果没有数据就不显示
例如 我们来看实例:
先建两张表:
create table student
(
id int primary key identity(1,1),
name varchar(50)
)
create table grade(
id int primary key identity(1,1),
score money
)
alter table grade add sid int
select * from grade
alter table grade add constraint fk_sid foreign key(sid) references student(id)
insert into student values('哈哈')
insert into student values('喜喜')
insert into student values('呵呵')
insert into student values('郁闷')
insert into student values('小强')
insert into student values('小马')
insert into grade values(90,1)
insert into grade values(80,2)
insert into grade values(70,null)
select * from student
select * from grade
内连接查询方式有两种:
1.select s.*,g.* from student s ,grade g where s.id=g.sid;
2.select s.*, g.* from student s inner join grade g on s.id=g.sid;
我们看到 我们主表没有主表没有匹配信息的时候 其他的记录没有显示
下面我们来看外连接:主要以从表信息为主 从表没有主表记录则显示为null
select s.*,g.* from student s left join grade g on s.id=g.sid
select s.*,g.* from student s right join grade g on s.id=g.sid
还可以是
select s.*,g.* from student s left outer join grade g on s.id=g.sid
select s.*,g.* from student s right outer join grade g on s.id=g.sid
看他是左还是右
下面来看看 完整连接:将两表的 左和右 基础数据全部查询出来 当一个表没有另一个表的记录的时候 则为nul 反之右表也是一样
select s.* ,g.* from student s full join grade g on s.id=g.sid
select s.* ,g.* from student s full outer join grade g on s.id=g.sid
交叉连接查询 :先返回 左表所有行,左表行在与右表行一一组合,等于两个表相乘
select s.*,g.* from student s cross join grade g
分享到:
相关推荐
本文将详细介绍六种主要类型的 JOIN:左连接(LEFT JOIN)、右连接(RIGHT JOIN)、全连接(FULL JOIN)、内连接(INNER JOIN)、交叉连接(CROSS JOIN)以及自连接(SELF JOIN)。通过实例讲解每种连接的特点和应用...
右连接、左连接、全连接、内连接、交叉连接、自连接
根据连接的方式不同,可以分为左连接(LEFT JOIN)、右连接(RIGHT JOIN)、内连接(INNER JOIN)、全连接(FULL JOIN)、交叉连接(CROSS JOIN)以及自连接(SELF JOIN)。每种连接类型都有其特定的应用场景和使用...
当使用`ON 1 = 1`作为连接条件时,交叉连接会返回两个表的所有可能组合,即每个左表的记录都会与右表的每条记录进行组合。例如: ```sql SELECT O.orderid, O.userid, U.userID, U.sname FROM t_order AS O CROSS ...
具体来说,它会从位于两个互相交叉的数据集合中找到重叠部分内的数据行,并将其连接起来。 **语法**: ```sql SELECT column_name(s) FROM table1 INNER JOIN table2 ON table1.column_name = table2.column_name; ...
交叉连接、内连接、外连接查询.sql
本文将详细解释五种主要的连接类型:外连接(外连接)、内连接(内连接)、左连接(LEFT JOIN)、右连接(RIGHT JOIN)、全连接(FULL JOIN)以及交叉连接(CROSS JOIN)。 1. **内连接(INNER JOIN)**: 内连接...
MySQL连接查询(多表连接查询:内连接,外连接,交叉连接详解) 6:多表连接查询 笛卡尔乘积:如果连接条件省略或无效则会出现 解决办法:添加上连接条件 连接查询的分类: 1.按年代分类: 1)sql 92标准:仅仅...
根据连接的方式和结果,SQL连接可以分为内连接、左连接、右连接、全连接和交叉连接等多种类型。 内连接 内连接是最基本的连接类型,它将两个表格中的数据根据某个条件连接起来。内连接可以分为等值连接、不等值...
交叉连接也称为笛卡尔积,它返回左表的每一行与右表的每一行的组合。如果两个表分别有n和m行,结果将有n*m行。 ```sql SELECT a.*, b.* FROM table_a CROSS JOIN table_b; ``` 在实际应用中,选择合适的连接...
本篇文章将深入探讨数据库连接查询,包括内连接、外连接和交叉连接等,同时结合实例来帮助理解。 首先,了解数据库的基础架构。Oracle数据库由Oracle数据库(数据文件、控制文件、重做日志文件等)和Oracle实例...
主要分为内连接、外连接和交叉连接,每种连接都有其特定的应用场景和逻辑。 内连接(INNER JOIN)是最常见的连接类型,它返回两个表中列相等的行。在内连接中,查询条件通常基于两个表之间的共同列,只有当这些列的...
交叉连接返回两个表的笛卡尔积,即每个左表的记录与右表的每个记录组合。如果没有WHERE子句,结果将是左表的行数乘以右表的行数。这通常会产生大量的记录,除非有明确的筛选条件。 6. **自连接**: 自连接是将同...
交叉连接返回所有可能的行组合,通常称为笛卡尔积。这在实际应用中并不常用,但在某些特定场景下可能会有用处。 - **交叉连接示例**: ```sql SELECT t.*, s.* FROM teacher t CROSS JOIN student s; ``` 通过...
交叉连接和内连接;表A; SELECT的查询对象由FROM子句指定,各个表用逗号分隔,这样就指定了交叉连接。 其格式为: FROM 表名1 [ [AS] 别名1 ] [ , 表名2[ [AS] 别名2]] … ; 【例】 members表和sell表进行交叉连???。...
交叉线连接开发板和主机 在嵌入式系统开发中,交叉线连接开发板和主机是一个非常重要的步骤。今天,我们将详细介绍如何使用交叉线连接开发板和主机,以便启动 NFS 根文件系统。 首先,让我们了解一下交叉线连接的...
SQL的几种连接:内连接、左联接、右连接、全连接、交叉连接
外连接 1.left join 示例:SQL语句:select * from student left join course on student.ID=course.ID 左外连接包含left join左表所有行,如果左表中某行在右表没有匹配,则结果中对应行右表的部分全部为...
连接类型主要有内连接、外连接和交叉连接,这些方法在数据分析、报表生成和数据整合等场景中发挥着关键作用。 首先,我们来详细讨论内连接(INNER JOIN)。内连接是最常用的连接类型,它返回两个表中满足特定连接...
此外,还有交叉连接(CROSS JOIN),也称为笛卡尔积,它会返回左表的每一行与右表的每一行的组合,结果集的大小是两个输入表行数的乘积。 在SQL代码示例中,使用临时表`@TA`和`@TB`展示了不同类型的连接。内连接的...