位置: 编程技术 - 正文

SQL 四种连接-左外连接、右外连接、内连接、全连接详解(sql语句连接方式)

编辑:rootadmin

推荐整理分享SQL 四种连接-左外连接、右外连接、内连接、全连接详解(sql语句连接方式),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql四种连接区别,sql连接4个表怎么写,sql的四种连接,sql连接种类有哪些,sql语句连接方式,sql各种连接的区别,sql的四种连接,sql各种连接的区别,内容如对您有帮助,希望把文章链接给更多的朋友!

SQL的四种连接-左外连接、右外连接、内连接、全连接

今天在看一个遗留系统的数据表的时候发现平时查找的视图是FULL OUT JOIN的,导致平时的数据记录要进行一些限制性处理,其实也可以设置视图各表为右外连接并在视图上设置各列的排序和筛选条件就可以达到效果。

联接条件可在FROM或WHERE子句中指定,建议在FROM子句中指定联接条件。WHERE和HAVING子句也可以包含搜索条件,以进一步筛选联接条件所选的行。

联接可分为以下几类:

1、内联接(典型的联接运算,使用像 = 或 <> 之类的比较运算符)。包括相等联接和自然联接。 内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行。例如,检索 students和courses表中学生标识号相同的所有行。

2、外联接。外联接可以是左向外联接、右向外联接或完整外部联接。 在 FROM子句中指定外联接时,可以由下列几组关键字中的一组指定:

1)LEFT JOIN或LEFT OUTER JOIN

左向外联接的结果集包括 LEFT OUTER子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。

2)RIGHT JOIN 或 RIGHT OUTER JOIN

右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。

3)FULL JOIN 或 FULL OUTER JOIN

完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。

3、交叉联接

交叉联接返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉联接也称作笛卡尔积。

FROM 子句中的表或视图可通过内联接或完整外部联接按任意顺序指定;但是,用左或右向外联接指定表或视图时,表或视图的顺序很重要。有关使用左或右向外联接排列表的更多信息,请参见使用外联接。

例子:

SQL 四种连接-左外连接、右外连接、内连接、全连接详解(sql语句连接方式)

------------------------------------------------- a表 id name b表 id job parent_id 1 张3 1 1 2 李四 2 2 3 王武 3 4 a.id同parent_id 存在关系

--------------------------------------------------

1) 内连接

select a.*,b.* from a inner join b on a.id=b.parent_id

结果是 1 张3 1 1 2 李四 2 2

2)左连接

select a.*,b.* from a left join b on a.id=b.parent_id

结果是 1 张3 1 1 2 李四 2 2 3 王武 null

3) 右连接

select a.*,b.* from a right join b on a.id=b.parent_id

结果是

1 张3 1 1 2 李四 2 2 null 3 4

4) 完全连接

select a.*,b.* from a full join b on a.id=b.parent_id

结果是

1 张3 1 1 2 李四 2 2 null    3 4 3 王武 null

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

centos 7系统下编译安装 mysql5.7教程 一、安装约定mysql安装路径:/usr/local/mysqlmysql数据库路径:/data/mysqlmy配置文件路径:/usr/local/mysql/my.cnf二、卸载mariadb#rpm-qa|grepmariadb#rpm-e--nodepsmariadb-libs-5

SQL Server 出现Error: 错误(管理器无法连接远程数据库)问题解决方案 SQLServer出现Error:错误我们在在使用SQLServer时都会遇到使用SQLServerManagementStudio无法连接远程数据库实例的问题,错误描述信息摘录如下:Anerrorhasoccurred

mysql表物理文件被误删的解决方法 前言1、该方法只介绍了如何救回这个表名(数据不恢复)如果想要恢复原来数据直接用extundelete把文件恢复后放回去即可2、并且是适用于平时没有全备的

标签: sql语句连接方式

本文链接地址:https://www.jiuchutong.com/biancheng/349273.html 转载请保留说明!

上一篇:Mysql事项,视图,函数,触发器命令(详解)(mysql事务视图)

下一篇:centos 7系统下编译安装 mysql5.7教程(centos7.4)

  • 什么是工程销项表
  • 商誉 会计
  • 结转已销售材料成本会计分录
  • 企业所得税汇算清缴账务处理
  • app 开发公司的账务处理
  • 存货跌价卖出需要进项转出吗
  • 法律责任的具体内容
  • 公司纳税人是什么意思是不是法人
  • 单位给职工租房属于福利政策文件
  • 超豪华小汽车消费税起征点
  • 个人定期存款利率怎么算
  • 怎么看是不是专用发票
  • 非公司车辆的使用费如何入账?
  • 建筑队能开哪些项目
  • 个体工商户做账可以做工资吗
  • 小规模可以不报增值税吗
  • 2021发票勾选认证
  • 缴纳房产税怎么办理登记手续
  • 物业费按年收取的规定
  • windows更新出现错误重新打开设置
  • 跨年怎么冲销发票
  • 利润为负数怎么调
  • 税控盘减免税款结转会计分录
  • 为员工购买的团员保险
  • 常见的dump抓取方法
  • windows11激活密钥多少钱
  • 应付票据开出票据的会计分录
  • php5.4升级到php7
  • html怎么引入图片
  • 税务稽查的进项税怎么处理
  • 社保缴费基数差1000一般差多少?
  • es工具类
  • 决算清理期和库款报解整理期
  • 法人借钱给公司,公司可以直接转给法人吗
  • 政府会计公共基础设施分类
  • 民非企业税金及附加是什么科目
  • 什么是记账凭证账务处理程序
  • 帝国cms导航站模板
  • 哪些计入管理费用哪些计入资本公积
  • 资产处置收益的账务处理
  • 财务费用的相关认定
  • 什么时候过路费减半收费
  • 第四季度报表和年报对不上
  • 商业折扣影响销售成本吗
  • 公司为职工提供免费午餐需要交纳个人所得税吗?
  • 递延所得税资产账务处理
  • 其他收益会计科目解释
  • 买房定金转给销售有效吗
  • 一年以上的借款是长期借款吗
  • 应交税费月底怎么结账
  • 对于审核后的凭证可直接修改对吗
  • 应交税费应交印花税贷方余额
  • 营业成本如何设一级科目
  • 账簿的概念与分类
  • sql树结构
  • 开启 windows server
  • Win10 64位系统下鼠标右键刷新没反应的解决方案
  • windows8.1安装windows7
  • 怎样开启bios
  • 怎么快速判断哪些角是第几象限
  • winload是什么
  • linux系统中安装软件的批处理文件
  • windows10 uac关闭
  • win10更新补丁后共享打印机无法使用
  • win10电脑补丁 kb5000802
  • py常用函数
  • unity中mathf
  • ai控制器的简称是
  • opengl坐标系原点
  • mysql定时脚本
  • 枚举的内容怎么输出
  • react基础入门
  • js alert()
  • angularjs2
  • apk反编译去广告教程
  • 欠税款要坐牢吗
  • 残疾人保障金税前扣除规定
  • 河南省电子票据查询平台
  • 上海网上申报软件怎样下载
  • 个人所得税网上报税流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设