热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

关于MySQL92和99等值连接、非等值连接、自连接、外连接及多表查询的代码示例总结!

关于MySQL92和99等值连接、非等值连接、自连接、外连接及多表查询的代码示例总结!一.MySQL92语法*1.内连接没有关联关系的数据是不在查询范围之内的*1

关于MySQL92和99 等值连接、非等值连接、自连接、外连接及多表查询的代码示例总结!

一. MySQL92语法

*1. 内连接 没有关联关系的数据是不在查询范围之内的
*
1)等值连接


– 查询出101的班级信息(并带上该班级的所有学生信息)


SELECT *FROM class,student WHERE class.`id`=student.`clazz_id` AND class.`name`='101';

– 查询出rose的所有信息(包括班级信息)


SELECT *FROM class,student WHERE class.`id`=student.`clazz_id`AND student.`name`='rose';

2)三表查询(多对多)


– 查询出rose的个人信息(包括其选修课程信息)


SELECT *FROM student,course,course_student WHERE student.`id`=course_student.`stu_id`AND course.`id`=course_student.`cou_id`AND student.`name`='rose';

– 查询出java这门课的信息(包括选该门课的学生)


SELECT * FROM student,course,course_studentWHERE student.`id`=course_student.`stu_id`AND course.`id`=course_student.`cou_id`AND course.`name`='hadoop';

3)一对一


– 查询出孙俪的个人信息(包括其丈夫的信息)


SELECT * FROM husband,wife WHERE wife.`wife_id`=husband.`wife_id` AND wife.`wife_name`='孙俪';

– 查询出所有班级的信息(包括其学生的信息)


SELECT * FROM class,student WHERE class.`id`=student.`clazz_id`;

4)非等值连接


– 查询出所有学生的信息(包括他的年龄级别)


SELECT *FROM student,age_tb WHERE student.`age`>=age_tb.`min`AND student.`age`<age_tb.`max`;

5)自连接


– 查询出北京市的信息(包括其区的信息)


SELECT *FROM city c1,city c2 WHERE c1.`id` =c2.`parent_id`AND c1.`name`=&#39;北京市&#39;;

2.外连接(不支持)

二. MySQL99语法

1.内连接
1)等值连接(对比)

-- 查询出101的班级信息(并带上该班级的所有学生信息)
SELECT *FROM class,student WHERE class.`id`=student.`clazz_id` AND class.`name`=&#39;101&#39;;SELECT *FROM class INNER JOIN student ON class.`id`=student.`clazz_id` WHERE class.`name`=&#39;101&#39;-- 查询出rose的所有信息(包括班级信息)
SELECT *FROM class,student WHERE class.`id`=student.`clazz_id`AND student.`name`=&#39;rose&#39;; SELECT *FROM class INNER JOIN student ON class.`id`=student.`clazz_id`WHERE student.`name`=&#39;rose&#39;

2)非等值连接

-- 查询出所有学生的信息(包括他的年龄级别)
SELECT *FROM student,age_tb WHERE student.`age`>=age_tb.`min`AND student.`age`<age_tb.`max`;SELECT *FROM student INNER JOIN age_tb ON student.`age`>=age_tb.`min`AND student.`age`<age_tb.`max`;

3)自连接

-- 查询出北京市的信息(包括其区的信息)
SELECT *FROM city c1,city c2 WHERE c1.`id` =c2.`parent_id`AND c1.`name`=&#39;北京市&#39;;SELECT *FROM city c1 INNER JOIN city c2 ON c1.`id` =c2.`parent_id`AND c1.`name`=&#39;北京市&#39;;

4)三表连接

-- 查询出rose的个人信息(包括其选修课程信息)
SELECT *FROM student,course,course_student WHERE student.`id`=course_student.`stu_id`AND course.`id`=course_student.`cou_id`AND student.`name`=&#39;rose&#39;;SELECT *FROM student INNER JOIN course JOIN course_studentON student.`id`=course_student.`stu_id`AND course.`id`=course_student.`cou_id`WHERE student.`name`=&#39;rose&#39;

5)一对一

-- 查询出孙俪的个人信息(包括其丈夫的信息)
SELECT * FROM husband,wife WHERE wife.`wife_id`=husband.`wife_id` AND wife.`wife_name`=&#39;孙俪&#39;;SELECT *FROM husband INNER JOIN wifeON wife.`wife_id`=husband.`wife_id` WHERE wife.`wife_name`=&#39;孙俪&#39;

-- 查询出所有班级的信息(包括其学生的信息)
SELECT * FROM class,student WHERE class.`id`=student.`clazz_id`;SELECT *FROM class INNER JOIN student ON class.`id`=student.`clazz_id`;

2.外连接
1)左外连接

-- 查询出所有班级的信息(包括其学生的信息)
SELECT *FROM classLEFT JOIN student ON class.`id`=student.`clazz_id`;-- 查询出所有学生的信息(包括其班级的信息)
SELECT *FROM student LEFT JOIN class ON class.`id`=student.`clazz_id`;

2)右外连接

-- 查询出所有学生的信息(包括其班级的信息)
SELECT *FROM class RIGHT JOIN student ON class.`id`=student.`clazz_id`;
-- 查询出所有班级的信息(包括其学生的信息)
SELECT *FROM student RIGHT JOIN class ON class.`id`=student.`clazz_id`;

3)全外连接(sql不支持)
左外和右外拼接

-- 查询学生和班级的所有数据
SELECT *FROM class LEFT JOIN student ON class.`id`=student.`clazz_id` #(结尾处不要写分号)
UNION
SELECT *FROM class RIGHT JOIN student ON class.`id`=student.`clazz_id`;

推荐阅读
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文探讨了2012年4月期间,淘宝在技术架构上的关键数据和发展历程。涵盖了从早期PHP到Java的转型,以及在分布式计算、存储和网络流量管理方面的创新。 ... [详细]
  • 全面解析运维监控:白盒与黑盒监控及四大黄金指标
    本文深入探讨了白盒和黑盒监控的概念,以及它们在系统监控中的应用。通过详细分析基础监控和业务监控的不同采集方法,结合四个黄金指标的解读,帮助读者更好地理解和实施有效的监控策略。 ... [详细]
  • 本文详细介绍了MySQL InnoDB存储引擎中的间隙锁概念及其作用,探讨了它在解决幻读问题方面的关键角色,并解析了间隙锁与其他操作之间的冲突关系。同时,文章还讨论了next-key-lock的构成及应用,以及在不同场景下的优化策略。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 解读MySQL查询执行计划的详细指南
    本文旨在帮助开发者和数据库管理员深入了解如何解读MySQL查询执行计划。通过详细的解析,您将掌握优化查询性能的关键技巧,了解各种访问类型和额外信息的含义。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 本文介绍如何通过创建替代插入触发器,使对视图的插入操作能够正确更新相关的基本表。涉及的表包括:飞机(Aircraft)、员工(Employee)和认证(Certification)。 ... [详细]
  • 本文讨论了如何根据特定条件动态显示或隐藏文件上传控件中的默认文本(如“未选择文件”)。通过结合CSS和JavaScript,可以实现更灵活的用户界面。 ... [详细]
  • 解决Element UI中Select组件创建条目为空时报错的问题
    本文介绍如何在Element UI的Select组件中使用allow-create属性创建新条目,并处理创建条目为空时出现的错误。我们将详细说明filterable属性的必要性,以及default-first-option属性的作用。 ... [详细]
  • 本文详细介绍了Python编程语言的学习路径,涵盖基础语法、常用组件、开发工具、数据库管理、Web服务开发、大数据分析、人工智能、爬虫开发及办公自动化等多个方向。通过系统化的学习计划,帮助初学者快速掌握Python的核心技能。 ... [详细]
  • 本文详细介绍了 Java 中的 org.apache.hadoop.registry.client.impl.zk.ZKPathDumper 类,提供了丰富的代码示例和使用指南。通过这些示例,读者可以更好地理解如何在实际项目中利用 ZKPathDumper 类进行注册表树的转储操作。 ... [详细]
  • 本文详细探讨了 org.apache.hadoop.ha.HAServiceTarget 类中的 checkFencingConfigured 方法,包括其功能、应用场景及代码示例。通过实际代码片段,帮助开发者更好地理解和使用该方法。 ... [详细]
author-avatar
阿克苏的风格
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有