我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql 连表查询

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql 连表查询

MySQL 连表查询可以通过使用 JOIN 语句来实现,基本语法如下:

SELECT 列名 FROM 表1 JOIN 表2 ON 表1.列名 = 表2.列名;

其中,JOIN 为关键字,表示连接查询,ON 后面是连接条件,列名前面应该加上表名或别名,以避免列名不唯一的情况。

例如,有两张表 orders 和 customers,orders 表中包含了所有订单信息,其中的 customerID 列存储着对应的客户 ID;customers 表中包含了所有客户信息,其中的 customerID 列是客户的唯一标识。

现在要查询所有订单的订单号和客户名称,可以使用以下 SQL 语句实现:

SELECT orders.orderID, customers.customerNameFROM ordersJOIN customersON orders.customerID = customers.customerID;

以上语句中,使用了 orders 和 customers 两张表,通过 ON orders.customerID = customers.customerID 指定了连接条件,同时指定了查询的两列为 orders.orderID 和 customers.customerName。

在 MySQL 中,常用的连表查询方式有以下几种:

  1. 内连接(INNER JOIN):只返回两个表中符合连接条件的匹配记录。

  2. 左连接(LEFT JOIN):返回左表中所有记录以及右表中符合连接条件的记录。

  3. 右连接(RIGHT JOIN):返回右表中所有记录以及左表中符合连接条件的记录。

  4. 全连接(FULL OUTER JOIN):返回左表和右表中所有记录,如果某个表中没有与另一个表匹配的记录,则补充 NULL 值。

其中,内连接是最常用的一种方式,常用于连接两个实体之间有关联的情况,例如员工与部门之间的关联。

以下是三种连接方式的语法示例:

内连接:

SELECT *FROM table1INNER JOIN table2ON table1.column = table2.column;

左连接:

SELECT *FROM table1LEFT JOIN table2ON table1.column = table2.column;

右连接:

SELECT *FROM table1RIGHT JOIN table2ON table1.column = table2.column;

注意,在使用连接查询的时候,一定要使用 ON 指定连接条件,避免产生笛卡尔积和数据的混乱等问题。

一般情况下,使用连接查询的效率要比子查询高。

因为连接查询可以将数据一次性从多个表中取出来,然后进行比较,不存在查询多次的情况,也不会占用过多的系统资源。而子查询通常需要先进行子查询操作,然后将查询结果存储在内存或者临时表中,最后再进行主查询,这就需要进行多次查询操作,且可能会导致系统内存占用过高,从而影响整个系统的性能。

但是,这并不意味着连接查询就永远比子查询优秀。在一些特殊的情况下,子查询反而可以比连接查询更加高效,例如需要在查询中进行多级嵌套,需要使用聚合函数或者子查询的结果集非常小等情况。此外,在实际使用中,还需要根据具体情况进行选择,综合考虑查询的复杂度、数据表的大小、查询的带宽等因素,选择合适的查询方式。

来源地址:https://blog.csdn.net/qq_27487739/article/details/130859039

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql 连表查询

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

下载Word文档

猜你喜欢

连接查询(多表查询)——MySQL

连接查询(多表查询) 又称多表查询,当查询的字段涉及多个表的时候,就要用到连接查询 分类: 为表起别名: 提高语句的简洁度区分多个重名字段注意:如果为表起了别名,则查询的字段就不能使用原来的别名去限定 内连接 查询A、B 交集部分数据 语
2023-08-18

mysql怎么做连表查询

mysql 使用 inner join 从多个表中关联数据,通过比较表中公用列进行关联。语法:select 列1, 列2, ...from 表1 inner join 表2 on 表1.公用列 = 表2.公用列;示例:select stud
mysql怎么做连表查询
2024-05-22

MySQL三个表的连接查询

MySQL三个表的连接查询 select first_name,title,salary,s.to_datefrom employees e inner join titles t on e.emp_no = t.emp_noinner join salari
2016-02-15

MybatisPlus多表连表查询

最近发现一个好玩的框架,我们知道mybatis-plus在连表查询上是不行的,如果需要连表查询,那么我们就得乖乖的去写xml文件了,但是今天发现一个新的框架 mybatis-plus-join。它既包含了mybatis-plus的所有优点,
2023-08-17

MySQL数据库:多表连接查询

多表连接查询注意:使用连接技术建议将表经行重命名!# explain 检索连接是否达标# 内连接 # 语法1from 表1 inner join 表2 on 主键字段=外键字段 [where 条件表达式] # 语法2 from 表1,表2 where 主键字段
2022-01-30

【MySQL系列】MySQL复合查询的学习 _ 多表查询 | 自连接 | 子查询 | 合并查询

「前言」文章内容大致是对MySQL复合查询的学习。 「归属专栏」MySQL 「主页链接」个人主页 「笔者」枫叶先生(fy) 目录 一、基本查询回顾二、多表查询三、自连接四、子查询4.1 单行子查询4.2 多行子查询4.
2023-08-30

【MySQL】MySQL表之联合查询(多表查询)

📌前言:本篇博客介绍MySQL数据库的MySQL表之联合查询(多表查询),学习MySQL之前要先安装好MySQL,如果还没有安装的小伙伴可以看看博主前面的博客,里面有详细的安装教程。 那我们废话不多说,直接进入主体!
2023-08-16

MySQL之单表查询、多表查询

一、单表查询:单个表的查询方法及语法顺序需要通过实际例子来熟悉先将表数据创建下:mysql> create database singe_t1; # 建个数据库singe_t1Query OK, 1 row affected (0.01
2023-01-31

MySQL之多表查询自连接方式

目录一、引言二、实操总结一、引言自连接,顾名思义就是自己连接自己。自连接的语法结构:表 A 别名 A join 表 A 别名 B ON 条件 ...;注意:1、这种语法有一个关键字:join2、自连接查询可以是内连接的语法,可以是外
MySQL之多表查询自连接方式
2024-09-05

mysql连接查询

11.5连接查询(列连接)问题:学生表有十条数据,成绩表有十条数据。连接之后有多少条数据(笛卡尔积):10*10=100 连续查询会产生笛卡尔积;假设集合A = {a,b},集合B = {c,d}两个集合的笛卡尔积{(a,c),(a,d)(b,c),(b,d)
mysql连接查询
2020-01-06

编程热搜

目录