Mysql 核心之数据查询

本贴最后更新于 2738 天前,其中的信息可能已经时移世易

数据查询是数据库最常用到的功能,熟练掌握查询的知识点是非常必要的。下面主要深入了解 Mysql 数据库的各种花式查询,如何跟据问题写出一条完美的 Sql.

查询语句的执行顺序

一、一条查询语句的分四个部分:
1、从哪个表。
2、查什么?对于查到的数据是 mysql 的基本数据类型,对于这些数据,我们能够可以进行运算【使用[算数/位]运算符】,使用函数做统计,或者数据处理。。常用聚合函数:Count,SUM ,MIN,MAX...等等。。。
3、过滤条件,数据满足什么条件的情况下获取它,这其中也会用到运算和函数,最常用的是比较运算,查找时间范围,数据范围,判断。。。
4、排序,topn,当我们过滤了数据之后,通常是分组,排序。。或者是获取其中一部分。

sql 语句写错可能是遇到最多的问题,主要还是由于没有搞清楚 sql 的解析过程,执行顺序。
二、sql 语句的正确写法

SELECT DISTINCT < select_list > FROM < left_table > < join_type > JOIN < right_table > ON < join_condition > WHERE < where_condition > GROUP BY < group_by_list > HAVING < having_condition > ORDER BY < order_by_condition > LIMIT < limit_number >

三、sql 语句的执行顺序


```sql 1 FROM 2 ON 3 JOIN 4 WHERE 5 GROUP BY 6 HAVING 7 SELECT 8 DISTINCT 9 ORDER BY 10 LIMIT ``` >在这里有几个比较容易错的点: >1、where/having的异同:'Group by'作为where与having的分界点,他们都是条件过滤,但是'having在group by之后,同时特也只能在group by之后',什么意思呢?就是说Having是对分组之后的数据聚合。而'where'必须在group by之前。 >2、在聚合函数使用和多表啦临河查询的时候,经常会使用别名,别名是为了方便其他地方用到,但是经常会出现提示别名不存在,那是因为在 在这个别名还未创建的时候哦我们就去使用它,例如: ``` #假设我查询用户表user 的性别sex人数count(sex)>20的数量 select count(sex) as ss from user group by sex having ss>20 这条语句能执行吗?貌似很完美,其实是错误的,ss这个别名根本找不到,回到上面的'执行顺序'我们可以看到,having在select之前执行,而count在select之后,我们只有首先获取到了原数据,才能聚合。所以having执行的时候这个count还没有执行呢,更不能定义ss这个别名了。所以会报错。 ``` # 四、执行顺序中的核心点 **第一部分**:1,2,3表示数据从哪里查,这里面最重要的就是多表联合,而核心就是笛卡儿积。如果我们连几张该怎么联合程我郁闷要的虚拟表都不清楚,那么更别说去查询这张表了。

第二部分:4,5,6 表示过滤条件,这部分只要搞清楚 where/having 使用的场景,以及条件中的运算和函数。就没什么问题。

第三部分:7,8 没什么说的,对查询出的数据使用函数如;count,distinct,sum,max.min....

第四部分:9,10 固定模式,我们取到最终的数据之后可以排序啊,取 topN.

表的交并,笛卡儿积

...待续

  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    345 引用 • 728 回帖
  • SQL
    127 引用 • 386 回帖 • 3 关注
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    692 引用 • 535 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
rzx
此生最怕深情被辜负,最怕兄弟成陌路。对世界充满善意,同时又充满深深的恨意,我渴望天降甘霖福泽众生,又渴望灭世洪水重创世纪。 广州

推荐标签 标签

  • Sphinx

    Sphinx 是一个基于 SQL 的全文检索引擎,可以结合 MySQL、PostgreSQL 做全文搜索,它可以提供比数据库本身更专业的搜索功能,使得应用程序更容易实现专业化的全文检索。

    1 引用 • 213 关注
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 5 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    179 引用 • 408 回帖 • 487 关注
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    21 引用 • 245 回帖 • 234 关注
  • 倾城之链
    23 引用 • 66 回帖 • 159 关注
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1708 回帖
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    6 引用 • 15 回帖 • 44 关注
  • danl
    163 关注
  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    286 引用 • 248 回帖 • 13 关注
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    84 引用 • 324 回帖 • 1 关注
  • OneDrive
    2 引用 • 3 关注
  • AWS
    11 引用 • 28 回帖 • 10 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    186 引用 • 318 回帖 • 259 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖 • 1 关注
  • Office

    Office 现已更名为 Microsoft 365. Microsoft 365 将高级 Office 应用(如 Word、Excel 和 PowerPoint)与 1 TB 的 OneDrive 云存储空间、高级安全性等结合在一起,可帮助你在任何设备上完成操作。

    5 引用 • 34 回帖 • 2 关注
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    210 引用 • 2040 回帖
  • Typecho

    Typecho 是一款博客程序,它在 GPLv2 许可证下发行,基于 PHP 构建,可以运行在各种平台上,支持多种数据库(MySQL、PostgreSQL、SQLite)。

    12 引用 • 67 回帖 • 444 关注
  • 开源中国

    开源中国是目前中国最大的开源技术社区。传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现、使用、并交流开源技术的平台。目前开源中国社区已收录超过两万款开源软件。

    7 引用 • 86 回帖
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    34 引用 • 467 回帖 • 758 关注
  • gRpc
    11 引用 • 9 回帖 • 89 关注
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 652 关注
  • 笔记

    好记性不如烂笔头。

    311 引用 • 796 回帖
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 568 关注
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    200 引用 • 120 回帖
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    169 引用 • 3834 回帖 • 1 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 45 关注
  • Follow
    4 引用 • 12 回帖 • 8 关注