MySQL中的多表联合查询功能怎么使用


本篇内容介绍了“MySQL中的多表联合查询功能怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!多表查询就是同时查询两个或两个以上的表,因为有的时候用户在查看数据的时候,需要显示的数据来自多张表.多表查询有以下分类:交叉连接查询[产生笛卡尔积,了解]内连接查询(使用的关键字inner join — inner可以省略)外连接查询(使用的关键字outer join -louter可以省略)子查询表自关联交叉连接查询返回被连接的两个表所有数据行的笛卡尔积笛卡尔积可以理解为一张表的每一行去和另外一张表的任意一行进行匹配假如A表有m行数据,B表有n行数据,则返回m*n行数据笛卡尔积会产生很多冗余的数据,后期的其他查询可以在该集合的基础上进行条件筛选格式实现结果内连接查询求多张表的交集格式操作inner可以省略操作外连接分为左外连接(left outer join)、右外连接(right outer join),满外连接(full outer join)。注意: oracle里面有full join,可是在mysql对full join支持的不好。我们可以使用unjion来达到目的。格式左外连接: left outer join
select* from A left outer join B on条件;
右外连接: right outer join
select* from A right outer join B on条件;
满外连接: full outer join
select * from A full outer join B on 条件;操作直接用fulljion会报错介绍子查询就是指的在一个完整的查询语句之中,嵌套若干个不同功能的小查询,从而一起完成复杂查询的一种编写形式,通俗一点就是包含select嵌套的查询。子查询可以返回的数据类型一共分为四种:单行单列:返回的是一个具体列的内容,可以理解为一个单值数据;单行多列:返回一行数据中多个列的内容;多行单列:返回多行记录之中同一列的内容,相当于给出了一个操作范围;多行多列:查询返回的结果是一张临时表操作在子查询中,有一些常用的逻辑关键字,这些关键字可以给我们提供更丰富的查询功能,主要关键字如下:1.ALL关键字
2.ANY关键字
3.SOME关键字
4.IN关键字
5.EXISTS关键字
格式特点ALL:与子查询返回的所有值比较为true则返回trueALL可以与=、>、>=、结合是来使用,分别表示等于、大于、大于等于、小于、小于等于、不等于其中的其中的所有数据。ALL表示指定列中的值必须要大于子查询集的每一个值,即必须要大于子查询集的最大值;如果是小于号即小于子查询集的最小值。同理可以推出其它的比较运算免费云主机域名符的情况。操作格式特点ANY:与子查询返回的任何值比较为true则返回trueANY可以与=、>、>=、结合是来使用,分别表示等于、大于、大于等于、小于、小于等于、不等于其中的其中的任何一个数据。表示制定列中的值要大于子查询中的任意一个值,即必须要大于子查询集中的最小值。同理可以推出其它的比较运算符的情况。SOME和ANY的作用一样,SOME可以理解为ANY的别名操作格式特点IN关键字,用于判断某个记录的值,是否在指定的集合中在IN关键字前边加上not可以将条件反过来操作格式特点该子查询如果“有数据结果”(至少返回一行数据),则该EXISTS()的结果为“true””,外层查询执行该子查询如果“没有数据结果”(没有任何数据返回),则该EXISTS()的结果为“false”,外层查询不执行EXISTS后面的子查询不返回任何实际数据,只返回真或假,当返回真时 where条件成立注意,EXISTS关键字,比IN关键字的运算效率高,因此,在实际开发中,特别是大数据量时,推荐使用EXISTS关键字操作概念MySQL有时在信息查询时需要进行对表自身进行关联查询,即一张表自己和自己关联,一张表当成多张表来用。注意自关联时表必须给表起别名。格式操作数据准备“MySQL中的多表联合查询功能怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注百云主机网站,小编将为大家输出更多高质量的实用文章!

相关推荐: vue中如何使用async和await

本文小编为大家详细介绍“vue中如何使用async和await”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue中如何使用async和await”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。async 是异步的意思,而 awai…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 03/10 16:14
下一篇 03/10 16:25

相关推荐