广告
返回顶部
首页 > 资讯 > 数据库 >MySQL数据库自连接实例讲解
  • 280
分享到

MySQL数据库自连接实例讲解

mysql自连接是什么mysql自连接查询数据库自链接 2023-06-11 09:06:53 280人浏览 薄情痞子
摘要

目录什么是自连接?自连接语法1、内连接1.1隐式内连接1.2.显式内连接2、外连接2.1.左外连接2.2.右外连接案例案例演示1案例演示2扩展需求总结什么是自连接?     &nb

什么是自连接?

        自连接可以理解为自己连接自己,在一张表上面所进行的操作;将一张表分成两张结构和数据完全一样的表(简单理解:相当于克隆了一张跟自己长得一模一样的表);

 但是问题来了,既然是两张一模一样的表,数据库怎么区分出那张表是哪张表呢?这时候最重要的一个知识点就来了,那就是给两张表分别取个别名。

自连接语法

自连接我所知道有以下几种语法,有遗漏的话也欢迎大家在评论区给我补充出来。

1、内连接

1.1隐式内连接

select 字段列表 from 表 [as] 表别名1,表  [as]  表别名2 where 条件...;

1.2.显式内连接

select 字段列表 from 表  [as]  表别名1 [inner] join 表  [as]  表别名2 on 条件...;

2、外连接

2.1.左外连接

select 字段列表 from 表  [as]  表别名1 left [outer] join 表  [as]  表别名2 on 条件...;

2.2.右外连接

select 字段列表 from 表  [as]  表别名1 right [outer] join 表  [as]  表别名2 on 条件...;

注:

1.语法和内外连接的语法一样,只不过换成了只在一张表上面操作。

2.[ ] 里面的单词 as 代表取别名,可写可不写;不写也可以取别名,用哪种都可以啦~☂♔

案例

可以自己插入表和数据跟着做一下。

案例演示1

商品表(tb_goods):

create table tb_Goods(
    id int primary key auto_increment comment '主键ID',
    goods varchar(50) not null comment '商品',
    price decimal(7,2) default 0.00 comment '商品价格'
) comment '商品表';

给商品表插入数据:

insert into tb_goods(goods,price) values('儿童牙刷',20),
                                        ('电动牙刷',10000),
                                        ('拼多多牙刷',9.9);
insert into tb_goods(goods) values('妈妈给买的牙刷');

数据展示: 

MySQL数据库自连接实例讲解

需求:

查询比 “拼多多牙刷” 的价格贵的牙刷有哪些?

思路解析(用的是隐式内连接),语法:

select 字段列表 from 表 [as] 表别名1,表  [as]  表别名2 where 条件...;

第一步:把 tb_goods(商品表)分成两张一模一样的表,分别取 g1 和 g2 两个别名,把它们连接起来;

select * from tb_goods as g1,tb_goods as g2;

查询结果如下:它会列出每条数据的组合情况,如下,每一种牙刷都能组成四种组合。

MySQL数据库自连接实例讲解

第二步:找出 g1 表里面的 “拼多多牙刷”;

select * from tb_goods as g1,tb_goods as g2 where g1.goods = '拼多多牙刷';

查询结果如下:

MySQL数据库自连接实例讲解

根据上面的语句查询出来的结果可以看到, g2 表里面的 g2.price 也已经把每个牙刷的价格查询出来了;

MySQL数据库自连接实例讲解

第三步:此时,只需要查询出 g2 所有牙刷的价格(g2.price)大于 g1 “拼多多牙刷”的价格(g1.price)的数据就可以了;

select * from tb_goods as g1,tb_goods as g2 where g1.goods = '拼多多牙刷' and g2.price > g1.price;

查询结果如下:在 g2 表里面,已经查出了大于 g1 “拼多多牙刷”的价格数据。

MySQL数据库自连接实例讲解

第四步:然后就可以把需要的数据进行查询;

select g2.goods,g2.price from tb_goods as g1,tb_goods as g2 where g1.goods = '拼多多牙刷' and g2.price > g1.price;

查询结果如下:得到了最终结果,比 “拼多多牙刷” 的价格贵的牙刷,完成了需求。

MySQL数据库自连接实例讲解

最后,如果要查询的数据更清晰的话,可以给查询的字段取别名;

select g2.goods as '商品',g2.price as '商品价格' from tb_goods as g1,tb_goods as g2 where g1.goods = '拼多多牙刷' and g2.price > g1.price;

查询结果如下:

MySQL数据库自连接实例讲解

温馨提醒您:取别名不加 as 也可以,只不过是我自己的个人习惯,嘿嘿~

同样的,用显示内连接也可以完成该需求:

select g2.* from tb_goods as g1 inner join tb_goods as g2 on g1.goods = '拼多多牙刷' where g2.price > g1.price;

查询结果如下:

MySQL数据库自连接实例讲解

用左外连接也可以完成该需求:

select g2.* from tb_goods as g1 left outer join tb_goods as g2 on g1.goods = '拼多多牙刷' where g2.price > g1.price;

查询结果如下:

MySQL数据库自连接实例讲解

案例演示2

学生表(tb_student):

create table tb_student(
    id int primary key auto_increment comment '主键ID',
    student_id char(2) not null unique comment '学号',
    name varchar(50) not null comment '姓名',
    age tinyint unsigned not null comment '年龄',
    parent_id char(2) comment '监护人ID'
)comment '学生表';

给学生表插入数据:

insert into tb_student(student_id, name, age,parent_id) VALUES('01','大头儿子',6,'03'),
                                                              ('03','小头爸爸',31,null),
                                                              ('02','小灰灰',5,'04'),
                                                              ('04','灰太狼',36,null);

数据展示:  

MySQL数据库自连接实例讲解

需求:

查询学生姓名及学生监护人姓名。

思路解析(用的是隐式内连接),语法:

select 字段列表 from 表 [as] 表别名1,表  [as]  表别名2 where 条件...;

第一步:把 tb_student(学生表)分成两张一模一样的表,分别取 s1 和 s2 两个别名,把它们连接起来;

select * from tb_student as s1,tb_student as s2;

MySQL数据库自连接实例讲解

第二步:看到这个需求,你可能会觉得奇怪,为什么都没有 学生监护人姓名 这个字段,而只有 学生监护人ID ;

MySQL数据库自连接实例讲解

 那是因为我们可以通过 学生监护人ID(parent_id) 关联 学生学号(student_id),找到该学生的学生监护人(student_id)。

MySQL数据库自连接实例讲解

比如:大头儿子的 学生监护人ID(parent_id)是 03,此时 03 学生学号(student_id)的家长为小头爸爸;

MySQL数据库自连接实例讲解

SQL 语句编写:

第一步:把 tb_student(学生表)分成两张一模一样的表,分别取 s1 和 s2 两个别名,把它们连接起来;

select * from tb_student as s1,tb_student as s2;

第二步:找到 s1 表的 学生监护人ID(parent_id)和 s2 表的 学生学号(student_id),把它们用 = 关联起来,意思就是:通过 学生监护人ID(parent_id)找到 学生学号(student_id);

select * from tb_student as s1,tb_student as s2 where s1.parent_id = s2.student_id;

查询结果如下:从查询出来的结果,就可以看到对应的 学生姓名(s1.name) 及 学生监护人姓名(s2.name) 都已经被找到了。

MySQL数据库自连接实例讲解

第三步:这时候就可以对学生姓名(s1.name)及学生监护人(s2.name)这两个数据进行查询;

select s1.name,s2.name from tb_student as s1,tb_student as s2 where s1.parent_id = s2.student_id;

查询结果如下:已经实现该需求。

MySQL数据库自连接实例讲解

最后,如果要查询的数据更清晰的话,可以给查询的字段取别名;

select s1.name as '学生姓名',s2.name as '学生监护人姓名' from tb_student as s1,tb_student as s2 where s1.parent_id = s2.student_id;

查询结果如下:

MySQL数据库自连接实例讲解

同样的,用显示内连接也可以完成该需求:

select s1.name '学生姓名',s2.name as '学生监护人姓名' from tb_student as s1 inner join tb_student s2 on s1.parent_id = s2.student_id;

查询结果如下:

MySQL数据库自连接实例讲解

扩展需求

在这个学生表(tb_student)里面,家长是没有归属人的,也就是 parent_id 为 <null> 的情况,比如小头爸爸和灰太狼; 

MySQL数据库自连接实例讲解

此时,我又有一个需求:我希望查询 学生姓名 及 学生的监护人 姓名,如果学生没有学生的监护人, 也要查询出来。

此时就不能使用内连接了,内连接只能查出它们相互交集的数据;要改成左外连接;

select s1.name '学生姓名',s2.name '学生监护人姓名' from tb_student as s1 left join tb_student as s2 on s1.parent_id = s2.student_id;

查询结果如下:

MySQL数据库自连接实例讲解

完。。。

总结

到此这篇关于Mysql数据库自连接实例讲解的文章就介绍到这了,更多相关mysql自连接内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL数据库自连接实例讲解

本文链接: https://www.lsjlt.com/news/261514.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL数据库自连接实例讲解
    目录什么是自连接?自连接语法1、内连接1.1隐式内连接1.2.显式内连接2、外连接2.1.左外连接2.2.右外连接案例案例演示1案例演示2扩展需求总结什么是自连接?     &nb...
    99+
    2023-06-11
    mysql自连接是什么 mysql自连接查询 数据库自链接
  • MySQL 自连接讲解
    目录 什么是自连接? 自连接语法 案例 案例演示1 案例演示2 扩展需求 什么是自连接?         自连接可以理解为自己连接自己,在一张表上面所进行的操作;将一张表分成两张结构和数据完全一样的表(简单理解:相当于克隆了一张跟自...
    99+
    2023-09-18
    数据库 mysql sql 自连接
  • Java连接MySQL数据库实例
    首先说明,由于是8版本的数据库,所以配置类的写法上与5版本的有所区别,需要注意,同时用idea或eclipse时需要导入jar包,jar包的下载链接: https://dev.mys...
    99+
    2022-11-13
  • Java操作数据库连接池案例讲解
    数据库连接池 概念:其实就是一个容器(集合),存放数据库连接的容器。 概念:其实就是一个容器(集合),存放数据库连接的容器。 当系统初始化好后,容器被创建...
    99+
    2022-11-12
  • Java连接Mysql数据库步骤详细讲解
    如何使用java连接mysql数据库? 使用 jdbc 连接 mysql 数据库。 详细讲解如下,请依次逐步观看,避免出错。 选择jdk版本 建议选择18以下的jdk,18版本以上可能会导致输出中文乱码。这里我们使用intellij ide...
    99+
    2023-09-03
    java mysql maven intellij-idea java-ee
  • Python实现Mysql数据库连接池实例详解
    python连接Mysql数据库: Python编程中可以使用MySQLdb进行数据库的连接及诸如查询/插入/更新等操作,但是每次连接MySQL数据库请求时,都是独立的去请求访问,相当浪费资源,而且访问数...
    99+
    2022-06-04
    详解 实例 数据库
  • Express连接MySQL及数据库连接池技术实例
    目录Express连接MySQL准备工作创建配置文件创建操作数据库的接口文件数据库连接池技术什么是数据库连接池数据库连接池的作用是什么?数据库连接池技术实例1、导入mysql模块2、...
    99+
    2022-11-13
  • scala 连接 MySQL 数据库案例
    1 依赖准备 mysql 8添加: mysql mysql-connector-java 8.0.29 mysql 5 添加: mysql mysql-conne...
    99+
    2023-10-20
    数据库 scala mysql
  • python3使用PyMysql连接mysql数据库实例
    python语言的3.x完全不向前兼容,导致我们在python2.x中可以正常使用的库,到了python3就用不了了.比如说mysqldb 目前MySQLdb并不支持python3.x , Python3....
    99+
    2022-06-04
    实例 数据库 PyMysql
  • PowerDesigner连接数据库的实例详解
    PowerDesigner连接数据库的实例详解PowerDesigner连接数据库 大致如下列图所示:选择需要连接的数据库类型:有两个选择,一、导入Sql脚本文件;二、连接数据源选择连接数据源:在弹出的对话框中选择相应的连接类型;方式有很多...
    99+
    2023-05-31
    powerdesigner 数据库 ne
  • JDBC连接数据库实例
    package javacommon.base; import java.sql.Connection; import java.sql.PreparedStatement;...
    99+
    2022-10-18
  • java基于jdbc连接mysql数据库功能实例详解
    本文实例讲述了java基于jdbc连接mysql数据库的方法。分享给大家供大家参考,具体如下:一、JDBC简介Java 数据库连接,(Java Database Connectivity,简称JDBC)是Java语言中用来规范客户端程序如何...
    99+
    2023-05-30
    java jdbc mysql
  • Node.js实现连接mysql数据库功能示例
    本文实例讲述了Node.js实现连接mysql数据库功能。分享给大家供大家参考,具体如下: Node.js连接数据库前,需要安装相应的包,如果安装sql server 需要先装包node-sqlserver...
    99+
    2022-06-04
    示例 功能 数据库
  • 基于C++实现Mysql数据库连接池实例
    目录项目技术点项目意义项目实现Connection设计ConnectionPool设计项目复杂接口细节刨析项目技术点 C语言进行mysql数据库编程无锁单例基于STL队列加C++11新特性保证线程安全实现的生产者消费者模...
    99+
    2022-12-07
    C++数据库连接池 C++mysql连接池
  • mysql 连接数据库
    1、首先启动mysql 并链接数据 小意思吧!都会了是吧    mysql -uroot -p //连接数据    net start mysql /...
    99+
    2022-05-21
    连接数据库 mysql
  • MySQL案例分析讲解外连接语法
    目录前言左连接例 1右连接例2作业记录前言 外连接可以分为左外连接和右外连接 左外连接: 包含左边表的全部行(不管右边的表中是否存在与它们匹配的行),以及右边表中全部匹配的行 右外连...
    99+
    2022-11-13
  • MySQL数据库约束操作示例讲解
    目录一、约束是什么二、约束的具体操作Not NULLUNIQUE约束的组合使用PRIMARY KEYDEFAULTFOREIGN KEY一、约束是什么 约束就是,在创建表的时候,对表设置一些规则,只有满足这些规则,才可以...
    99+
    2022-11-15
    MySQL数据库约束 MySQL约束
  • mysql数据库无连接自动关闭怎么解决
    本篇内容主要讲解“mysql数据库无连接自动关闭怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql数据库无连接自动关闭怎么解决”吧!windows...
    99+
    2022-11-30
    mysql
  • Express连接MySQL及数据库连接池的示例分析
    这篇文章主要介绍Express连接MySQL及数据库连接池的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Express连接MySQL准备工作打开webstorm新建项目选择express创建一个expres...
    99+
    2023-06-29
  • 云数据库MongoDB 连接MongoDB实例
    要连接云数据库MongoDB实例,您可以按照以下步骤进行操作:1. 登录到云数据库MongoDB控制台。2. 在左侧导航栏中,选择“...
    99+
    2023-09-21
    数据库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作