中国统计网|SQL太难?你离完全理解SQL就差这10步!


- 点击上方“中国统计网”设置?星标不迷路!-
中国统计网|SQL太难?你离完全理解SQL就差这10步!
本文插图
很多程序员视 SQL 为洪水猛兽 。 SQL 是一种为数不多的声明性语言 , 它的运行方式完全不同于我们所熟知的命令行语言、面向对象的程序语言、甚至是函数语言(尽管有些人认为 SQL 语言也是一种函数式语言) 。
我们每天都在写 SQL 并且应用在开源软件 jOOQ 中 。 于是我想把 SQL 之美介绍给那些仍然对它头疼不已的朋友 , 所以本文是为了以下读者而特地编写的:

  • 在工作中会用到 SQL 但是对它并不完全了解的人
  • 能够熟练使用 SQL 但是并不了解其语法逻辑的人
  • 想要教别人 SQL 的人
本文着重介绍SELECT 句式 , 其他的 DML(Data Manipulation Language 数据操纵语言命令)将会在别的文章中进行介绍 。011
SQL 是一种声明式语言
首先要把这个概念记在脑中:“声明” 。 SQL 语言是为计算机声明了一个你想从原始数据中获得什么样的结果的一个范例 , 而不是告诉计算机如何能够得到结果 。 这是不是很棒?(译者注:简单地说 , SQL 语言声明的是结果集的属性 , 计算机会根据 SQL 所声明的内容来从数据库中挑选出符合声明的数据 , 而不是像传统编程思维去指示计算机如何操作 。 )SELECTfirst_name, last_nameFROMemployeesWHEREsalary >100000上面的例子很容易理解 , 我们不关心这些雇员记录从哪里来 , 我们所需要的只是那些高薪者的数据(译者注:salary>100000 ) 。我们从哪儿学习到这些?如果 SQL 语言这么简单 , 那么是什么让人们“闻 SQL 色变”?主要的原因是:我们潜意识中的是按照命令式编程的思维方式思考问题的 。 就好像这样:“电脑 , 先执行这一步 , 再执行那一步 , 但是在那之前先检查一下是否满足条件 A 和条件 B ” 。 例如 , 用变量传参、使用循环语句、迭代、调用函数等等 , 都是这种命令式编程的思维惯式 。2
SQL 的语法并不按照语法顺序执行
SQL 语句有一个让大部分人都感到困惑的特性 , 就是:SQL 语句的执行顺序跟其语句的语法顺序并不一致 。 SQL 语句的语法顺序是:
  • SELECT[DISTINCT]
  • FROM
  • WHERE
  • GROUP BY
  • HAVING
  • UNION
  • ORDER BY
为了方便理解 , 上面并没有把所有的 SQL 语法结构都列出来 , 但是已经足以说明 SQL 语句的语法顺序和其执行顺序完全不一样 , 就以上述语句为例 , 其执行顺序为:
  • FROM
  • WHERE
  • GROUP BY
  • HAVING
  • SELECT
  • DISTINCT
  • UNION
  • ORDER BY
关于 SQL 语句的执行顺序 , 有三个值得我们注意的地方:1.FROM 才是 SQL 语句执行的第一步 , 并非 SELECT。 数据库在执行 SQL 语句的第一步是将数据从硬盘加载到数据缓冲区中 , 以便对这些数据进行操作 。(译者注:原文为“The first thing that happens is loading data from the disk into memory, in order to operate on such data.” , 但是并非如此 , 以 Oracle 等常用数据库为例 , 数据是从硬盘中抽取到数据缓冲区中进行操作 。 )2.SELECT 是在大部分语句执行了之后才执行的 , 严格的说是在 FROM 和 GROUP BY 之后执行的 。 理解这一点是非常重要的 , 这就是你不能在 WHERE 中使用在 SELECT 中设定别名的字段作为判断条件的原因 。SELECTA.x + A.yASz FROMA WHEREz =10-- z 在此处不可用 , 因为SELECT是最后执行的语句!


推荐阅读