• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > mysql子查询是什么?mysql数据库子查询实际使用示例

mysql子查询是什么?mysql数据库子查询实际使用示例

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了mysql数据库子查询语句等相关知识,希望本文的分享对您有所帮助
mysql子查询是什么?

子查询,又叫内部查询,相对于内部查询,包含内部查询的就称为外部查询。子查询允许把一个查询嵌套在另一个查询当中。

mysql数据库子查询语句的特点:任何可使用表达式的地方,都可以使用子查询,只要他返回的是单个值;子查询按返回值的数量,子查询对外部依赖性,比较运算符的不同性进行分类;这在分页查询sql语句中经常用到。

一:子查询的特点:

  1. 子查询可被嵌套在 select,insert,update,delete 等语句中

  2. 大多数情况下子查询充当中间结果集角色

  3. 子查询可进行嵌套,且根据内存及表达式复杂程度不同,嵌套限制也不同

  4. 任何可使用表达式的地方,都可以使用子查询,只要他返回的是单个值

二:子查询的分类:

  1. 按返回值的数量可分为:标量子查询,多值子查询

  2. 按子查询对外部依赖性:独立子查询,相关子查询

  3. 按比较运算符的不同性:IN,EXISTS,ANY,SOME,ALL等多种形式

三:子查询的使用:

  1. 首先创建两个表(学生表和教师表)

    # 创建学生表
    mysql> create table tb_student(
        -> stu_ID long,
        -> class varchar(5),
        -> score int
        -> );
    Query OK, 0 rows affected (0.23 sec)
    
    # 创建教师表
    mysql> create table tb_teacher(
        -> tea_ID long,
        -> class varchar(5),
        -> age int
        -> );
    Query OK, 0 rows affected (0.49 sec)
  2. 将一些值插入到表中

    insert into tb_student values(1, "A", 20);
    
    insert into tb_student values(2, "A", 30);
    
    insert into tb_student values(3, "A", 70);
    
    insert into tb_student values(4, "B", 60);
    
    insert into tb_student values(5, "B", 70);
    
    insert into tb_student values(6, "B", 80);
    
    insert into tb_teacher values(1, "A", 25);
    
    insert into tb_teacher values(2, "B", 40);
  3. 准备工作完毕,接下来进行子查询练习

  • 例一:各班教师ID及其班级平均分数

    mysql> select tea_ID,
        -> (select avg(score) from tb_student as s where s.class = t.class group by class)
        -> as Avg from tb_teacher as t;
    +--------+---------+
    | tea_ID | Avg     |
    +--------+---------+
    | 1      | 40.0000 |
    | 2      | 70.0000 |
    +--------+---------+
    2 rows in set (0.00 sec)
  • 例二:各班级教师年龄及其班级及格人数(60为及格线)

    mysql> select age,
        -> (select count(*) from tb_student as s where s.class = t.class && s.score >= 60 group by class)
        -> as Count from tb_teacher as t order by Count desc;
    +------+-------+
    | age  | Count |
    +------+-------+
    |   40 |     3 |
    |   25 |     1 |
    +------+-------+
    2 rows in set (0.00 sec)

相关推荐:

mysql 分页查询语句数据库查询_MySQL

Mysql limit子查询语句_MySQL

视频:高级数据查询 - where子句-六天带你玩转MySQL

以上就是mysql子查询是什么?mysql数据库子查询实际使用示例的详细内容,更多请关注微课江湖其它相关文章!

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2018-12-05mysql增删改查--CURD操作
  • 2017-05-11mysql 获取当天发布的信息的语句
  • 2018-12-05MySQL 用户权限详细汇总
  • 2018-12-05MySQL 不允许从远程访问的问题
  • 2018-12-05实现mysql行转列和列转行的示例代码分享
  • 2018-12-05总结sql语句技巧实例用法
  • 2017-05-11Mysql Error Code : 1436 Thread stack overrun
  • 2018-12-05[DB][MyBatis]利用mybatis-paginator实现分页
  • 2017-05-11库名表名大小写问题与sqlserver兼容的启动配置方法
  • 2017-05-11PHP5 mysqli的prepare准备语句使用说明

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • MySQL索引操作命令小结
    • MySQL中按时间获取慢日志信息的方法
    • executesql 存储过程
    • SQL 语句中In 和 Where 的不同点
    • 浅谈MySQL漂流记(四)
    • SQL Server 海量数据导入的最快方法
    • MySQL终端管理数据库操作指南
    • DB2和 Oracle的并发控制(锁)的比较_Oracle应用_脚本之家
    • mssql 建立索引第1/2页
    • MySQL分组排序取前N条记录 以及 生成自动数字序列 的SQL

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有