热门标签 | 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`;

推荐阅读
  • 2018年人工智能大数据的爆发,学Java还是Python?
    本文介绍了2018年人工智能大数据的爆发以及学习Java和Python的相关知识。在人工智能和大数据时代,Java和Python这两门编程语言都很优秀且火爆。选择学习哪门语言要根据个人兴趣爱好来决定。Python是一门拥有简洁语法的高级编程语言,容易上手。其特色之一是强制使用空白符作为语句缩进,使得新手可以快速上手。目前,Python在人工智能领域有着广泛的应用。如果对Java、Python或大数据感兴趣,欢迎加入qq群458345782。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • javascript  – 概述在Firefox上无法正常工作
    我试图提出一些自定义大纲,以达到一些Web可访问性建议.但我不能用Firefox制作.这就是它在Chrome上的外观:而那个图标实际上是一个锚点.在Firefox上,它只概述了整个 ... [详细]
  • 安卓select模态框样式改变_微软Office风格的多端(Web、安卓、iOS)组件库——Fabric UI...
    介绍FabricUI是微软开源的一套Office风格的多端组件库,共有三套针对性的组件,分别适用于web、android以及iOS,Fab ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 基于事件驱动的并发编程及其消息通信机制的同步与异步、阻塞与非阻塞、IO模型的分类
    本文介绍了基于事件驱动的并发编程中的消息通信机制,包括同步和异步的概念及其区别,阻塞和非阻塞的状态,以及IO模型的分类。同步阻塞IO、同步非阻塞IO、异步阻塞IO和异步非阻塞IO等不同的IO模型被详细解释。这些概念和模型对于理解并发编程中的消息通信和IO操作具有重要意义。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • Win10 64位旗舰版的优势及特点详解
    本文详细介绍了Win10 64位旗舰版的优势及特点,包括更安全的源安装盘、永久激活方式、稳定性和硬件驱动的集成,以及人性化的维护工具和分区功能。通过阅读本文,您将了解到Win10 64位旗舰版相比其他版本的优势和特点。 ... [详细]
  • 本文整理了Java中org.apache.hadoop.hive.ql.plan.ExprNodeColumnDesc.getTypeInfo()方法的一些代码示例,展 ... [详细]
  •     这里使用自己编译的hadoop-2.7.0版本部署在windows上,记得几年前,部署hadoop需要借助于cygwin,还需要开启ssh服务,最近发现,原来不需要借助cy ... [详细]
  • Maven构建Hadoop,
    Maven构建Hadoop工程阅读目录序Maven安装构建示例下载系列索引 序  上一篇,我们编写了第一个MapReduce,并且成功的运行了Job,Hadoop1.x是通过ant ... [详细]
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社区 版权所有