SQL中的左连接与右连接,内连接有什么不同

SQL中的左连接与右连接,内连接有什么不同

我们来举个例子。天庭上面有一个管理系统:管理系统有个主表:主表记录着各个神仙的基本信息(我们把它当成表A)。还有个表记录着他们这个神仙的详细信息(我们把它当成表B)。

表A的信息为

idA name position
1 李靖 托塔天王
2 值年神李丙 四值功曹
3 增长天王 四大天王
4 青龙孟章神君 四方神

表B的信息为(此神仙有无犯过天条)

IDB Name THINGS
1 NO
3 YES 上班玩忽职守
4 NO
5 NO
6 YES 调戏嫦娥妹妹

刚好赶上天庭蟠桃会,王母就让你统计下,参加蟠桃会的人有无犯事的记录,有的话就取消他参加宴会的资格。

这个时候,你用上了 左连接 方法

语句为下:select A.* ,B.* from A left outer join B on (A.IDA=B.IDB)

IDA NAME position IDB Name THINGS
1 李靖 托塔天王 1 NO
2 值年神李丙 四值功曹 NULL NULL NULL
3 增长天王 四大天王 3 YES 上班玩忽职守
4 青龙孟章神君 四方神 4 NO

结果就如同这样,表B中的IDB=5和6这条数据没有展示出来。且IDA=2 这条数据在表B中取null,左连接取的就是FROM后面该表中的所有数据作为查询结果。

但是如果你用了右连接:

语句为下:select A.* ,B.* from A right outer join B on (A.IDA=B.IDB)

IDA NAME position IDB Name THINGS
1 李靖 托塔天王 1 NO
3 增长天王 四大天王 3 YES 上班玩忽职守
4 青龙孟章神君 四方神 4 NO
NULL NULL NULL 5 NO
NULL NULL NULL 6 YES 调戏嫦娥妹妹

这个时候王母一看。什么,居然有人调戏 嫦娥,而且还查不到这个人?王母就会大发雷霆然后限你一天之内找到这个人。

内连接和自然连接的写法一样

select * from A,B where A.IDA=B.IDB

IDA NAME position IDB Name THINGS
1 李靖 托塔天王 1 NO
3 增长天王 四大天王 3 YES 上班玩忽职守
4 青龙孟章神君 四方神 4 NO

整体来概述一下,这些的区别是什么:

通俗易懂

左连接:左边有的,右边没有的为null

右连接:左边没有的,右边有的为null

内连接:显示左边右边共有的

原文地址:https://www.cnblogs.com/jianshuai520/p/11055519.html

时间: 2024-10-31 13:03:37

SQL中的左连接与右连接,内连接有什么不同的相关文章

mysql多表查询方法(left join(左连接),right join (右连接),inner join (内连接)的区别)

表A记录如下:  aID aNum  1 a20050111  2 a20050112  3 a20050113  4 a20050114  5 a20050115  表B记录如下:  bID bName  1 2006032401  2 2006032402  3 2006032403  4 2006032404  8 2006032408  创建这两个表SQL语句如下:  CREATE TABLE a  aID int( 1 ) AUTO_INCREMENT PRIMARY KEY ,  a

sql中一个服务器建立另一个服务器的连接

EXEC sp_addlinkedserver 'TonyLink','','SQLOLEDB','111.111.1.111(服务器名)' EXEC sp_addlinkedsrvlogin 'TonyLink','false',NULL,'账号','密码' TonyLink 是固定的 SELECT *FROM TonyLink.ETLDB.dbo.aaaa sql中一个服务器建立另一个服务器的连接

SQLServer学习笔记<> 表连接查询----交叉连接、内连接、左连接、右连接

(1)交叉连接(cross join)即我们所说的笛卡尔积.查询出满足两张表所有的记录数,A(3条记录),B(9条记录),A*B(27条记录). 比如:雇员表(HR.employees)和货运公司(Sales.shippers)表做一个交叉连接. 1 select * from hr.employees; 2 select * from sales.shippers; 进行交叉连接以后,则找到27条记录. 1 select a.empid,b.shipperid 2 from hr.employ

c++中的左值与右值

++(a++) a++相当于 int a; { int temp=a; a++; teturn temp; } 所以我们可以将++(a++)看成++temp;而temp 显然是一个右值,所以不能用啊~~ L-value中的L指的是Location,表示可寻址.The "l" in lvalue can be though of as locationR-value中的R指的是Read,表示可读.The "r" in rvalue can be thought of

4.1 中的左值和右值

摘要:  引自---http://www.cnblogs.com/catch/p/3500678.html 左值 (lvalue)和右值 (rvalue) 是 c/c++ 中一个比较晦涩基础的概念,有的人可能甚至没有听过,但这个概念到了 c++11 后却变得十分重要,它们是理解 move, forward 等新语义的基础. 左值右值的定义 左值与右值这两概念是从 c 中传承而来的,在 c 中,左值指的是既能够出现在等号左边也能出现在等号右边的变量(或表达式),右值指的则是只能出现在等号右边的变量

C++中的左值和右值

左值和右值的定义 在C++中,可以放到赋值操作符=左边的是左值,可以放到赋值操作符右边的是右值.有些变量既可以当左值又可以当右值.进一步来讲,左值为Lvalue,其实L代表Location,表示在内存中可以寻址,可以给它赋值(常量const类型也可以寻址,但是不能赋值),Rvalue中的R代表Read,就是可以知道它的值.例如: int a=3; a在内存中有地址,而3没有,但是可以read到它的值. 3=4; 这个是错误的,因为3的内存中没有地址,不能当作左值. 下面这个语句不容易出错 a++

DB2数据库的外连接(OUTER JOIN),内连接(INNER JOIN)和交叉连接(CROSS JOIN)区别

1.交叉连接(CROSS JOIN):有两种,显式的和隐式的,不带ON子句,返回的是两表的乘积,也叫笛卡尔积,返回记录的个数应当是a和b表中符合记录的和. 显式:select [cols_list] from a cross join b where [condition] 隐式:select [cols_list] from a, b where [condition] 2.内连接(INNER JOIN):有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行,和我们写普通的sql

SQL中的左连接与右连接有什么区别,点解返回值会不同?(转)

例子,相信你一看就明白,不需要多说 A表(a1,b1,c1) B表(a2,b2) a1 b1 c1 a2 b2 01 数学 95 01 张三 02 语文 90 02 李四 03 英语 80 04 王五 select A.*,B.* from A left outer join B on(A.a1=B.a2) 结果是: a1 b1 c1 a2 b2 01 数学 95 01 张三 02 语文 90 02 李四 03 英语 80 NULL NULL select A.*,B.* from A righ

数据库左连接left join、右连接right join、内连接inner join on 及 where条件查询的区别

join on 与 where 条件的执行先后顺序: join on 条件先执行,where条件后执行:join on的条件在连接表时过滤,而where则是在生成中间表后对临时表过滤 left join.right join.full join.inner join区别: left join:以左表为基准,根据on条件过滤连接生成临时表,on后面的过滤条件对左表无效 right join:以右表为基准,根据on条件过滤连接生成临时表,on后面的过滤条件对右表无效 full join:以左表为基准