美文网首页数据库
MySQL的三种子查询

MySQL的三种子查询

作者: 软件测试大田 | 来源:发表于2022-03-10 02:17 被阅读0次

今天学习 MySQL 子查询,先来干货再看看实际中如何运用。

一、何为子查询?

一条 select 查询语句的结果, 作为另一条 select 语句的一部分。

二、子查询特点?

1、子查询要放在小括号里

2、子查询作为父查询的查询条件使用。

三、子查询分类?

1、where 型语法:

SELECT 查询字段 FROM 表 WHERE 字段=(子查询);

2、from 型语法:

SELECT 查询字段 FROM (子查询)表别名 WHERE 条件;

3、exists 型( in 函数)语法:

SELECT 查询字段 FROM 表 WHERE 字段 IN (子查询);

四、举例子说明实际中如何使用

有 products 商品表

图片

有 category 类目表:

图片

1、where 型例子:

通过子查询的方式, 查询价格最高的商品信息

# 通过子查询的方式, 查询价格最高的商品信息

# 1.首先查询出最高价格

SELECT MAX(price) FROM products;

# 2.将最高价格作为条件,获取商品信息

SELECT * FROM products WHERE price

= (SELECT MAX(price) FROM products);

图片

2、from 型例子:

查询商品中,价格大于500的商品信息,包括 商品名称 商品价格 商品所属分类名称

select

  p.`pname`,

  p.`price`,

  c.cname

from

  products p

inner join (

  select

    *

  from

    category) c on # 此处c:子查询作为一张表使用时,要起别名,才能访问表中字段

  p.`category_id` = c.cid

where

  p.`price` > 500;

图片

3、exists 型例子:

查询家电类与鞋服类下面的全部商品信息

select

  *

from

  products

where

  category_id in (

  select

    cid

  from

    category

  where

    cname in ('家电', '鞋服'));

图片

今天先学一点点,明天见

相关文章

  • mysql 查询

    mysql的查询、子查询及连接查询 一、mysql查询的五种子句 where(条件查询)、having(筛选)、g...

  • mysql的查询、子查询及连接查询

    一、mysql查询的五种子句 where(条件查询)、having(筛选)、group by(分组)、order ...

  • InnoDB引擎中查询锁的信息

    InnoDB中查询锁的信息主要基于三个查询语句 MySQL 5.7 MySQL 8.0 本文将分别基于 MySQL...

  • MySQL 中的三种子查询

    本篇开始是子查询的学习笔记,首先是一道题目: 查出最新的(goods_id 最大)的一条商品,比较简单,按照 or...

  • mysql索引查询

    参考文档:explain命令mysql慢查询优化 一、主键和索引的区别 二、mysql查询时如何使用索引 三、ex...

  • 十一、慢查询分析工具

    mysql 慢查询分析工具一: mysql安装后自动安装mysqldumpslow慢查询工具 使用方法 分析前三条...

  • MySQL听讲(六)——查询

    说到查询,首先想到了的是索引。本节基于MySQL听讲(三)——索引 的基础来对查询进行展开。 mysql索引选择策...

  • MYSQL(一)---基础架构(查询)

    1.MYSQL(一)---基础架构(查询)2.MYSQL(二)---日志系统(更新)3.MYSQL(三)---事务...

  • MYSQL(二)---日志系统(更新)

    1.MYSQL(一)---基础架构(查询)2.MYSQL(二)---日志系统(更新)3.MYSQL(三)---事务...

  • MYSQL(三)---事务隔离

    1.MYSQL(一)---基础架构(查询)2.MYSQL(二)---日志系统(更新)3.MYSQL(三)---事务...

网友评论

    本文标题:MySQL的三种子查询

    本文链接:https://www.haomeiwen.com/subject/mtccdrtx.html