MySQL学习之连接查询

  1. 笛卡尔乘积现象

在表的连接查询方面有一种现象被称为:笛卡尔积现象。

笛卡尔积现象:

当两张表进行连接查询的时候,没有任何条件进行限制,最终的查询结果条数是两张表记录条数的乘积。

select ename,dname from emp,dept;

避免笛卡尔积现象:

连接时加条件,满足条件的记录筛选出来。

思考:避免了笛卡尔积现象,会减少记录的匹配次数吗?

         不会,次数还是56次。只不过显示的是有效记录。

关于表的别名:

        select e.ename,d.dname from emp e,dept d;

        表的别名有什么好处?

                第一:执行效率高。

                第二:可读性好。

mysql> select

->  e.ename,d.dname

-> from

->  emp as e,dept as d

-> where

->  e.deptno = d.deptno;

  1. 内连接:等值连接

SQL99语法结构更清晰一些:

表的连接条件和后来的where条件分离了。

SQL92语法:

mysql> select

    ->          e.ename,d.dname

    -> from

    ->          emp as e,dept as d

    -> where

->          e.deptno = d.deptno;

SQL99语法:

mysql> select

    ->          e.ename,d.dname

    -> from

    ->          emp as e

    -> join

    ->          dept as d

    -> on

    ->          e.deptno = d.deptno;

//inner 可以省略(带着inner可读性更好!!!一眼就能看出来是内连接)

SQL99语法:

Select

........

From

A

Innner jion

B

On

a和b的连接条件

Where

筛选条件

  1. 内连接:非等值连接

最大的特点是:连接条件中的关系是非等量关系

mysql> select

    ->  e.ename,e.sal,s.grade

    -> from

    ->  emp e

    ->(inner) join

    ->  salgrade s

    -> on

->  e.sal between s.losal and hisal;

  1. 内连接:自连接

最大的特点是:一张表看做两张表。自己连接自己。

mysql> select

    ->  a.ename as '员工名',b.mgr as '领导名'

    -> from

    ->  emp a

    -> join

    ->  emp b

    -> on

    -> a.mgr = b.empno;

  1. 外连接

内连接:

假设AB表进行连接,使用内连接的话,凡是A表和B表能够匹配上的记录查询出来,这就是内连接。

AB两张表没有主副之分,两张表是平等的。

外连接:

假设AB表进行连接,使用外连接的话,AB两张表中有一张表是主表,一张表是副表,主要查询主表中

的数据,捎带着查询副表,当副表中的数据没有和主表中的数据匹配上,副表自动模拟出NULL与之匹配。

外连接的分类?

左外连接(左连接):表示左边的这张表是主表。 left  (outer)  join

右外连接(右连接):表示右边的这张表是主表。  right  (outer)  join

Outer 可省略

左连接有右连接的写法,右连接也会有对应的左连接的写法。

mysql> select

    ->          e.ename,d.dname

    -> from

    ->          emp as e

    -> right (outer) join

    ->          dept as d

    -> on

    ->          e.deptno = d.deptno;

mysql> select

    ->          e.ename,d.dname

    -> from

    ->          dept as d   

-> left (outer) join

    ->          emp as e

    -> on

    ->          e.deptno = d.deptno;

连接最重要的特点是:主表的数据无条件的全部查询出来。

  1. 三张表连接/多张表连接

注意,解释一下:

     

一条SQL中内连接和外连接可以混合。都可以出现!

        表示:A表和B表先进行表连接,连接之后A表继续和C表进行连接。

  1. 子查询

where子句中使用子查询

From子句中使用子查询

注意(技巧): from后面的子查询,可以将子查询的查询结果当做一张临时表。

此时有个注意点:平均值avg()是特殊函数,需起别名使用!

在select后面嵌套子查询

mysql> select

    ->   e.ename,(select d.dname from dept d where d.deptno = e.deptno) result

    -> from

->  emp e;

  1. union (可以将查询结果集相加)

mysql> select ename,job from emp where job = 'manager' or job  = 'salesman';

mysql> select ename,job from emp where job in ('manager' ,'salesman');

mysql> select ename,job from emp where job = 'manager'

    -> union

    -> select ename,job from emp where job = 'salesman';

//union的效率更高,union 把乘法变成了加法。

表连接来说,每连接一次新表。则匹配的次数满足笛卡尔积,成倍得翻

但是union可以减少匹配的次数。

在减少匹配次数的情况下,

还可以完成两个结果集的拼接。

a连接 b 连接 C

a  10条记录

B  10条记录

C  10条记录

匹配次数是: 1000

a 连接 b一个结果: 10*10 --> 100次

a 连接 C一个结果: 10 * 10 --> 100次

使用union的话是: 100次 + 100次 =200

union在使用的时候有注意事项吗?

//错误的: union在进行结果集合并的时候,要求两个结果集的列数相同。

select ename ,job from emp where job =’ MANAGER’

union

select ename from emp where job = 'SALESMAN';

// MYSQL可以,oracle语法严格 ,不可以,报错。要求: 结果集合并时列和列的数据类型也需要一致。

select ename ,job from emp where job = ‘MANAGER’

union

select ename ,sal from emp where job = 'SALESMAN';

  1. Limit(重点中的重点,以后分页查询全靠它了。)
  • limit是mysql特有的,其他数据库中没有,不通用。(Oracle中有一个相同的机制,叫做rownum)
  • limit取结果集中的部分数据,这是它的作用。
  • 语法机制:

       limit startIndex, length

               startIndex表示起始位置,从0开始,0表示第一条数据。

               length表示取几个

      

  • limit是sql语句最后执行的一个环节:

        select                     5

                ...

        from                       1

                ...            

        where                    2

                ...    

        group by                3

                ...

        having                    4

                ...

        order by                6

                ...

        limit                        7

                ...;

mysql> select ename from emp order by sal desc limit 0,5;

mysql> select ename from emp order by sal desc limit 5;

  • 分页

每页显示pageSize条记录:

第pageNo页:(pageNo - 1) * pageSize, pageSize

pageSize是什么?是每页显示多少条记录

pageNo是什么?显示第几页

通用的标准分页sql?

每页显示3条记录:

第1页:0, 3

第2页:3, 3

第3页:6, 3

第4页:9, 3

第5页:12, 3

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/292731.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算法系列--动态规划--特殊的状态表示--分析重复子问题

💕"轻舟已过万重山!"💕 作者:Lvzi 文章主要内容:算法系列–算法系列–动态规划–特殊的状态表示–分析重复子问题 大家好,今天为大家带来的是算法系列--动态规划--特殊的状态表示--分析重复子问题 一.组合总数IV 链接…

实现富文本的三部曲

1、引入 ueditor.config.js ueditor.all.min.js lang/zh-cn/zh-cn.js 2、编辑器显示处 id"content" <textarea id"content" name"content"></textarea> 3、底部 <script type"text/javascript"> //实例化编辑器 …

搜索与图论——Floyd算法求最短路

floyd算法用来求多源汇最短路 用邻接矩阵来存所有的边 时间复杂度O(n^3) #include<iostream> #include<cstring> #include<algorithm>using namespace std;const int N 20010,INF 1e9;int n,m,k; int g[N][N];void floyd(){for(int k 1;k < n;k ){f…

网络基础(二)——序列化与反序列化

目录 1、应用层 2、再谈“协议” 3、网络版计算器 Socket.hpp TcpServer.hpp ServerCal.hpp ServerCal.cc Protocol.hpp ClientCal.cc Log.hpp Makefile 1、应用层 我们程序员写的一个个解决我们实际问题&#xff0c;满足我们日常需求的网络程序&#xff0c;都是在…

QT+Opencv+yolov5实现监测

功能说明&#xff1a;使用QTOpencvyolov5实现监测 仓库链接&#xff1a;https://gitee.com/wangyoujie11/qt_yolov5.git git本仓库到本地 一、环境配置 1.opencv配置 将OpenCV-MinGW-Build-OpenCV-4.5.2-x64文件夹放在自己的一个目录下&#xff0c;如我的路径&#xff1a; …

appium辅助自动化工具-- Appium studio

这里我要给大家介绍一款appium辅助自动化测试工具appium studio&#xff0c;你没看错&#xff0c;不是android studio&#xff0c;也不是appium android studio&#xff0c;就是appium studio&#xff01; 下载地址&#xff1a; Appium Studio | Digital.ai Continuous Test…

智慧公厕的技术融合策略

智慧公厕是迎合现代城市发展需要的一项重要基础设施&#xff0c;其设计的技术融合策略在实现公共厕所泛在感知、互通互联、协同构筑智慧城市等方面起到了关键作用。本文将以智慧公厕源头实力厂家广州中期科技有限公司&#xff0c;大量精品案例现场实景实图实例&#xff0c;从物…

Makefile:动态库的编译链接与使用(六)

1、动态链接库 动态链接库&#xff1a;不会把代码编译到二进制文件中&#xff0c;而是运行时才去加载&#xff0c;所以只需要维护一个地址 动态&#xff1a;运行时才去加载&#xff0c;即所谓的动态加载连接&#xff1a;指库文件和二进制程序分离&#xff0c;用某种特殊的手段…

MySQL - 高阶语句(一)

先准备一张表 create table class1 (id int,name varchar(10) primary key not null ,score decimal(5,2),address varchar(20),hobbid int(5));insert into class1 values(1,liuyi,80,beijing,2); insert into class1 values(2,wangwu,90,shengzheng,2); insert into class1 …

图腾柱PFC:HP1010为您的电动两轮车之旅提供绿色,高效,安全的动力

电动两轮车不仅为当今生活提供了便利&#xff0c;更是一种健康和绿色的出行方式。想象一下&#xff0c;在经过一整晚的充分休息&#xff0c;骑上爱车&#xff0c;满血复活的准备开始新的一天。您会愿意带着如何给心爱的两轮车充电的担心开始这一天吗&#xff1f; 随着越来越…

第1章.提示词:开启AI智慧之门的钥匙

什么是提示词&#xff1f; 提示词&#xff0c;是引导语言模型的指令&#xff0c;让用户能够驾驭模型的输出&#xff0c;确保生成的文本符合需求。 ChatGPT&#xff0c;这位文字界的艺术大师&#xff0c;以transformer架构为基石&#xff0c;能轻松驾驭海量数据&#xff0c;编织…

JUC并发编程(七)

1、不可变对象 1.1、概念 不可变类是指一旦创建对象实例后&#xff0c;就不能修改该实例的状态。这意味着不可变类的对象是不可修改的&#xff0c;其内部状态在对象创建后不能被更改。不可变类通常具有以下特征&#xff1a; 实例状态不可改变&#xff1a;一旦不可变类的对象被…

中药知识分享

中药知识分享 声明&#xff1a;本文根据《懒兔子》公众号公益视频整理&#xff0c;参考网络信息略有改动&#xff0c;图片来源于网络&#xff0c;如有侵权&#xff0c;请联系删除。文章内容如有不正确之处请指正批评。仅供学习使用。请勿擅自服用本文提及的药材&#xff0c;否…

http响应练习—在服务器端渲染html(SSR)

一、什么是服务器端渲染&#xff08;SSR&#xff09; 简单说&#xff0c;就是在服务器上把网页生成好&#xff0c;整个的HTML页面生成出来&#xff0c;生成出的页面已经包含了所有必要的数据和结构信息&#xff0c;然后直接发给浏览器进行展现。 二、例题 要求搭建http服务&a…

pymysql使用记录

最近由于需要来学习一下pymysql。 先来认识一下pymysql&#xff1a; PyMySQL 是 Python 中一个用于连接 MySQL 数据库的库。它允许 Python 程序通过简单的 API 调用来连接、操作和管理 MySQL 数据库。PyMySQL 是在 Python 中使用纯 Python 编写的&#xff0c;因此它可以在几…

2024/3/31周报

文章目录 摘要Abstract文献阅读题目创新点实验数据研究区域数据和材料 方法XGBoost algorithmLong Short‑Term Memory AlgorithmEvaluation of the Model Accuracy 实验结果 深度学习XGBoost代码实现AdaBoostBoostingAdaBoost算法AdaBoost代码实现 总结 摘要 本周阅读了一篇基…

Mamba: Linear-Time Sequence Modeling with Selective State Spaces(论文笔记)

What can I say? 2024年我还能说什么&#xff1f; Mamba out! 曼巴出来了&#xff01; 原文链接&#xff1a; [2312.00752] Mamba: Linear-Time Sequence Modeling with Selective State Spaces (arxiv.org) 原文笔记&#xff1a; What&#xff1a; Mamba: Linear-Time …

NFC RC522开发记录

文章目录 一、ID卡、IC卡(M1卡、CPU卡)的区别二、RC522读写操作1. 数据读写流程三、RC522驱动代码1. RC522 与 STM32 的接线图2. RC522.c3. RC522.h4. main.c一、ID卡、IC卡(M1卡、CPU卡)的区别 ID卡 :只存储了ID号,设备识别ID号,没有算法可言,容易复制,安全性低IC卡包含了…

Unity-C#进阶——3.27更新中

文章目录 数据结构类ArrayListStackQueueHashtable 泛型泛型类、泛型方法、泛型接口ListDictionaryLinkedList泛型栈&#xff0c;泛型队列 委托和事件委托事件匿名函数Lambad 表达式**闭包** List 排序逆变协变多线程进程线程多线程方法&#xff1a;线程之间共享数据&#xff1…

洛谷_P2437 蜜蜂路线_python写法_高精度加法

目录 1. 40分代码 2.高精度加法 3.全AC代码 4.惊掉下巴的解法 P2437 蜜蜂路线 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 1. 40分代码 m, n map(int,input().split())ans 0 d [1,2] flag [0 for _ in range(n1)] def fun(step):global ansif step n:ans 1return…