mysql的内外查询分别是什么?

mysql的内查询是通过设置连接条件的方式,利用条件表达式来消除交叉连接的某些数据行,查询结果都是符合连接条件的记录;而外查询会先将连接的表分为基表和参考表,再以基表为依据返回满足和不满足条件的记录。

mysql的内外查询分别是什么?

(推荐教程:mysql视频教程)

MySQL INNER JOIN:内连接查询

内连接(INNER JOIN)主要通过设置连接条件的方式,来移除查询结果中某些数据行的交叉连接。简单来说,就是利用条件表达式来消除交叉连接的某些数据行。

内连接使用 INNER JOIN 关键字连接两张表,并使用 ON 子句来设置连接条件。如果没有连接条件,INNER JOIN 和 CROSS JOIN 在语法上是等同的,两者可以互换。

内连接的语法格式如下:

SELECT  FROM  INNER JOIN  [ON子句]

语法说明如下:

字段名:需要查询的字段名称。

蓝心千询 蓝心千询

蓝心千询是vivo推出的一个多功能AI智能助手

蓝心千询 34 查看详情 蓝心千询

:需要内连接的表名。

INNER JOIN :内连接中可以省略 INNER 关键字,只用关键字 JOIN。

ON 子句:用来设置内连接的连接条件。

INNER JOIN 也可以使用 WHERE 子句指定连接条件,但是 INNER JOIN … ON 语法是官方的标准写法,而且 WHERE 子句在某些时候会影响查询的性能。

多个表内连接时,在 FROM 后连续使用 INNER JOIN 或 JOIN 即可。

内连接可以查询两个或两个以上的表。为了让大家更好的理解,暂时只讲解两个表的连接查询。

示例

在 tb_students_info 表和 tb_course 表之间,使用内连接查询学生姓名和相对应的课程名称,SQL 语句和运行结果如下。

mysql> SELECT s.name,c.course_name FROM tb_students_info s INNER JOIN tb_course c     -> ON s.course_id = c.id;+--------+-------------+| name   | course_name |+--------+-------------+| Dany   | Java        || Green  | MySQL       || Henry  | Java        || Jane   | Python      || Jim    | MySQL       || John   | Go          || Lily   | Go          || Susan  | C++         || Thomas | C++         || Tom    | C++         |+--------+-------------+10 rows in set (0.00 sec)

在这里的查询语句中,两个表之间的关系通过 INNER JOIN 指定,连接的条件使用 ON 子句给出。

注意:当对多个表进行查询时,要在 SELECT 语句后面指定字段是来源于哪一张表。因此,在多表查询时,SELECT 语句后面的写法是表名.列名。另外,如果表名非常长的话,也可以给表设置别名,这样就可以直接在 SELECT 语句后面写上表的别名.列名。

MySQL LEFT/RIGHT JOIN:外连接查询

内连接的查询结果都是符合连接条件的记录,而外连接会先将连接的表分为基表和参考表,再以基表为依据返回满足和不满足条件的记录。

外连接可以分为左外连接和右外连接,下面根据实例分别介绍左外连接和右外连接。

左连接

左外连接又称为左连接,使用 LEFT OUTER JOIN 关键字连接两个表,并使用 ON 子句来设置连接条件。

左连接的语法格式如下:

SELECT  FROM  LEFT OUTER JOIN  

语法说明如下。

字段名:需要查询的字段名称。

:需要左连接的表名。

LEFT OUTER JOIN:左连接中可以省略 OUTER 关键字,只使用关键字 LEFT JOIN。

ON 子句:用来设置左连接的连接条件,不能省略。

上述语法中,“表1”为基表,“表2”为参考表。左连接查询时,可以查询出“表1”中的所有记录和“表2”中匹配连接条件的记录。如果“表1”的某行在“表2”中没有匹配行,那么在返回结果中,“表2”的字段值均为空值(NULL)。

例 1

在进行左连接查询之前,我们先查看 tb_course 和 tb_students_info 两张表中的数据。SQL 语句和运行结果如下。

mysql> SELECT * FROM tb_course;+----+-------------+| id | course_name |+----+-------------+|  1 | Java        ||  2 | MySQL       ||  3 | Python      ||  4 | Go          ||  5 | C++         ||  6 | HTML        |+----+-------------+6 rows in set (0.00 sec)mysql> SELECT * FROM tb_students_info;+----+--------+------+------+--------+-----------+| id | name   | age  | sex  | height | course_id |+----+--------+------+------+--------+-----------+|  1 | Dany   |   25 | 男   |    160 |         1 ||  2 | Green  |   23 | 男   |    158 |         2 ||  3 | Henry  |   23 | 女   |    185 |         1 ||  4 | Jane   |   22 | 男   |    162 |         3 ||  5 | Jim    |   24 | 女   |    175 |         2 ||  6 | John   |   21 | 女   |    172 |         4 ||  7 | Lily   |   22 | 男   |    165 |         4 ||  8 | Susan  |   23 | 男   |    170 |         5 ||  9 | Thomas |   22 | 女   |    178 |         5 || 10 | Tom    |   23 | 女   |    165 |         5 || 11 | LiMing |   22 | 男   |    180 |         7 |+----+--------+------+------+--------+-----------+11 rows in set (0.00 sec)

在 tb_students_info 表和 tb_course 表中查询所有学生姓名和相对应的课程名称,包括没有课程的学生,SQL 语句和运行结果如下。

mysql> SELECT s.name,c.course_name FROM tb_students_info s LEFT OUTER JOIN tb_course c     -> ON s.`course_id`=c.`id`;+--------+-------------+| name   | course_name |+--------+-------------+| Dany   | Java        || Henry  | Java        || NULL   | Java        || Green  | MySQL       || Jim    | MySQL       || Jane   | Python      || John   | Go          || Lily   | Go          || Susan  | C++         || Thomas | C++         || Tom    | C++         || LiMing | NULL        |+--------+-------------+12 rows in set (0.00 sec)

可以看到,运行结果显示了 12 条记录,name 为 LiMing 的学生目前没有课程,因为对应的 tb_course 表中没有该学生的课程信息,所以该条记录只取出了 tb_students_info 表中相应的值,而从 tb_course 表中取出的值为 NULL。

右连接

右外连接又称为右连接,右连接是左连接的反向连接。使用 RIGHT OUTER JOIN 关键字连接两个表,并使用 ON 子句来设置连接条件。

右连接的语法格式如下:

SELECT  FROM  RIGHT OUTER JOIN  

语法说明如下。

字段名:需要查询的字段名称。

:需要右连接的表名。

RIGHT OUTER JOIN:右连接中可以省略 OUTER 关键字,只使用关键字 RIGHT JOIN。

ON 子句:用来设置右连接的连接条件,不能省略。

与左连接相反,右连接以“表2”为基表,“表1”为参考表。右连接查询时,可以查询出“表2”中的所有记录和“表1”中匹配连接条件的记录。如果“表2”的某行在“表1”中没有匹配行,那么在返回结果中,“表1”的字段值均为空值(NULL)。

例 2

在 tb_students_info 表和 tb_course 表中查询所有课程,包括没有学生的课程,SQL 语句和运行结果如下。

mysql> SELECT s.name,c.course_name FROM tb_students_info s RIGHT OUTER JOIN tb_course c     -> ON s.`course_id`=c.`id`;+--------+-------------+| name   | course_name |+--------+-------------+| Dany   | Java        || Green  | MySQL       || Henry  | Java        || Jane   | Python      || Jim    | MySQL       || John   | Go          || Lily   | Go          || Susan  | C++         || Thomas | C++         || Tom    | C++         || NULL   | HTML        |+--------+-------------+11 rows in set (0.00 sec)

可以看到,结果显示了 11 条记录,名称为 HTML 的课程目前没有学生,因为对应的 tb_students_info 表中并没有该学生的信息,所以该条记录只取出了 tb_course 表中相应的值,而从 tb_students_info 表中取出的值为 NULL。

多个表左/右连接时,在 ON 子句后连续使用 LEFT/RIGHT OUTER JOIN 或 LEFT/RIGHT JOIN 即可。

使用外连接查询时,一定要分清需要查询的结果,是需要显示左表的全部记录还是右表的全部记录,然后选择相应的左连接和右连接。

相关推荐:php培训

以上就是mysql的内外查询分别是什么?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/357580.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 01:28:34
下一篇 2025年11月6日 01:33:00

相关推荐

  • Golang抽象工厂模式在项目中的使用

    抽象工厂模式通过接口定义创建一系列相关对象的工厂,Go中利用接口和组合实现,如根据不同环境配置创建数据库与缓存组合,业务代码依赖接口而非具体实现,提升可维护性和扩展性,符合开闭原则。 在Go语言项目中,抽象工厂模式常用于解耦对象的创建逻辑与业务逻辑,尤其适合需要创建一系列相关或依赖对象的场景。它通过…

    2025年12月15日
    000
  • 如何使用Golang的竞态检测器(race detector)发现潜在的并发问题

    Golang竞态检测器通过运行时监控内存访问来发现并发bug,使用-race标志即可启用,能输出竞态类型、调用栈和内存地址等信息,帮助定位读-写或写-写竞态问题,如counter++未加锁导致的数据竞争;其原理是在编译时插入监控代码,虽增加开销但有效,仅建议测试阶段使用,且需结合代码审查与其他工具如…

    2025年12月15日
    000
  • Golang项目如何连接MySQL数据库并执行基本的SQL查询

    首先安装MySQL驱动,然后使用database/sql包连接数据库并执行查询。通过sql.Open()建立连接,db.Ping()测试连通性,QueryRow()查询单行,Query()查询多行并遍历结果,Exec()执行插入等操作,最后用Scan()读取数据并处理错误。完整示例展示了查询用户列表…

    2025年12月15日
    000
  • 在Golang中如何利用反射实现一个简单的依赖注入容器

    答案:Go语言通过反射实现依赖注入容器,利用tag标记需注入字段,并在运行时自动赋值。具体步骤包括定义容器结构体存储类型与实例映射,提供Register注册实例,Inject方法通过反射遍历结构体字段,识别inject:”true”标签的字段并注入对应实例。示例中UserSe…

    2025年12月15日
    000
  • Golang项目结构的最佳实践是如何组织包和目录

    Golang项目结构应遵循可维护性与领域驱动设计,推荐结构包括cmd、internal、pkg等目录,错误处理通过显式返回error实现,依赖注入常用构造函数注入,单元测试使用testing包和_test.go文件编写。 Golang项目结构组织的核心在于可维护性、可扩展性和可读性。没有绝对的“最佳…

    2025年12月15日
    000
  • 在Golang中处理数据库操作返回的sql.ErrNoRows的正确方式

    正确处理sql.ErrNoRows的方式是将其视为正常业务状态,使用errors.Is(err, sql.ErrNoRows)识别并根据场景返回nil、自定义错误或空集合,避免与数据库错误混淆。 在Golang中处理 sql.ErrNoRows ,最正确且符合Go语言哲学的方式是将其视为一种正常的业…

    2025年12月15日
    000
  • 为什么我的Golang环境变量在重启电脑后就失效了

    Golang环境变量重启后失效因未持久化,需将GOROOT、GOPATH及bin路径写入系统配置文件。Linux/macOS用户应编辑~/.bashrc或~/.zshrc,添加export指令并source生效;Windows用户可通过系统属性或setx命令设置环境变量。验证可通过echo和go e…

    2025年12月15日
    000
  • Golang数据库错误处理 SQL错误转换技巧

    答案:在Golang中处理SQL错误需通过类型断言和错误码转换,如MySQL的1062错误码表示唯一键冲突,应构建统一错误映射层以提升可维护性。 在使用 Golang 进行数据库开发时,错误处理是确保程序健壮性的关键环节,尤其是对 SQL 错误的识别与转换。由于 Go 的 database/sql …

    2025年12月15日
    000
  • Golang的下划线导入(import _)通常用于什么场景

    下划线导入用于触发包的init函数,如注册数据库驱动、执行初始化操作、实现接口副作用或加载静态分析工具插件,避免过度使用可提升代码可读性。 下划线导入在Golang中主要用于触发包的init()函数,即使你并不直接使用这个包中的任何变量或函数。这在一些特定场景下非常有用,比如注册数据库驱动或者执行一…

    2025年12月15日
    000
  • 为什么不推荐在Golang的init函数中执行复杂的逻辑

    不推荐在Go的init函数中执行复杂逻辑,因其会导致启动慢、调试难、测试复杂、错误无法返回等问题;init适合处理无副作用的简单任务,如注册驱动、编译正则等;复杂初始化应通过显式函数、依赖注入或延迟初始化在main中控制,以提升可维护性与稳定性。 在Go语言中,我个人真的不推荐在 init 函数里头…

    2025年12月15日
    000
  • Golang中如何使用goroutine实现一个简单的定时任务调度器

    答案:通过goroutine和channel实现并发定时任务调度,利用time.Ticker精确控制执行间隔,结合context.Context实现优雅启动、停止及单个任务取消,确保并发安全与资源释放,为后续扩展cron表达式、持久化、分布式等高级功能奠定基础。 在Golang中,利用其原生的gor…

    2025年12月15日
    000
  • Golang中非main包里的init函数会按照什么顺序执行

    init函数按依赖关系自底向上执行,同一包内按文件编译顺序执行;循环依赖会导致编译错误;init中panic会终止程序启动;应避免复杂逻辑以提升可维护性。 Golang中,非 main 包的 init 函数执行顺序并非完全线性,它受到包的导入关系和文件编译顺序的影响。简单来说,它会按照依赖关系自底向…

    2025年12月15日
    000
  • Golang实现简单爬虫怎么做 组合net/http与goquery解析HTML

    答案:使用Golang实现爬虫需先用net/http发送请求并处理错误、超时和重定向,再通过goquery结合CSS选择器解析HTML提取数据,最后利用goroutine和channel实现并发抓取,配合WaitGroup同步,数据可存为文件或数据库。 用Golang实现一个简单的爬虫,核心思路其实…

    2025年12月15日
    000
  • Golang实现短链接服务 算法与存储设计

    短链接服务核心是唯一标识生成与高效存储。采用“分布式ID+Base62编码”算法可保证唯一性与较短长度,结合“MySQL/PostgreSQL+Redis”存储架构,利用Redis缓存高频读取,数据库持久化保证一致性,Golang通过goroutine处理高并发,配合连接池、异步队列与监控实现高性能…

    2025年12月15日
    000
  • Google App Engine Go 应用中的状态管理与持久化策略

    本文旨在解决Google App Engine (GAE) Go 应用中因实例自动伸缩导致的内存变量重置问题。当GAE启动新进程时,应用内存中的数据会丢失。核心解决方案是避免将关键数据存储在RAM中,而应利用GAE提供的持久化存储服务,如Memcache、Datastore等,以确保数据在不同实例间…

    2025年12月15日
    000
  • Golang错误处理与数据库操作 SQL错误转换技巧

    答案:Go中数据库错误处理需通过errors.As提取底层错误并结合SQL状态码进行精准转换,避免依赖错误消息字符串。应封装统一的错误映射函数,将驱动错误(如PostgreSQL的23505唯一键冲突)转化为应用级错误,提升代码健壮性与可维护性。 在Go语言开发中,错误处理和数据库操作是两个高频且关…

    2025年12月15日
    000
  • Golang初级项目完整指南 从零到上线

    对于初学者来说,从零开始搭建并成功上线一个Go语言项目,关键在于理解其简洁高效的特性,并遵循一套从概念到部署的实践路径。这不仅仅是写几行代码,更是一次系统性思考和解决问题的过程,涵盖了从项目初始化、依赖管理、核心逻辑开发、测试到最终部署上线的全链路。 解决方案 要将一个Go语言初级项目从零带到线上,…

    2025年12月15日
    000
  • Golang如何集成数据库开发环境 常见数据库驱动配置

    首先引入database/sql标准库和对应数据库驱动,如MySQL的github.com/go-sql-driver/mysql;通过sql.Open()使用DSN连接数据库,需正确配置用户名、密码、地址等信息;导入驱动时使用下划线表示仅执行初始化注册;成功获取*sql.DB实例后,应设置连接池参…

    2025年12月15日
    000
  • Golang网络编程中的连接池管理 对比不同连接池实现方案

    连接池能显著提升性能和资源利用率。在没有连接池时,每次请求需新建并关闭tcp连接,耗时且易导致资源限制问题;使用连接池后可复用连接,减少开销,并控制最大连接数防止资源耗尽。常见连接池库包括database/sql(适合数据库场景但配置有限)、net/http transport(内置http连接复用…

    2025年12月15日 好文分享
    000
  • Golang实现云原生数据库代理 分库分表中间件开发

    答案:基于Golang构建云原生数据库代理需集成SQL解析、路由引擎、连接池与结果合并模块,选用vitess或TiDB解析器,支持分库分表路由策略,结合Kubernetes实现服务发现与弹性伸缩,通过Prometheus监控保障稳定性。 要用 Golang 实现云原生数据库代理,并支持分库分表,核心…

    2025年12月15日
    000

发表回复

登录后才能评论
关注微信