SQL 是一种声明式语言吗?

11,574次阅读
没有评论

共计 2660 个字符,预计需要花费 7 分钟才能阅读完成。

当面对复杂的任务时,难度急剧增加,有些任务无法单独使用 SQL 来实现,因为它不是图灵完备的。

Sql 是什么?

在学习 SQL 的时候,我们经常听到这样的说法:SQL 是一种声明性语言。你只需要告诉它做什么;不用告诉它怎么做,它就会找到自己的实现方法。也就是说,你只需要用它来描述任务目标,而不需要解释计算过程,这与传统的过程语言有本质的区别。显然,这种编程语言听起来更容易学习和使用。

真的有那么好吗?

让我们看一个例子。我们使用 SQL 来查询销售部门的女性员工人数。这是写好的 SQL:

看起来是这样的:我们不需要关心具体的计算过程(遍历 employee 表中的每一条记录,符合条件的则 count 加 1,不符合则跳过,最后看 count)),只需说出要查询的目标即可。

我们再看一个例子:按部门查找 30 岁以上员工的平均工资:

看起来也不错。在这里,我们真的不必关心如何分组和计算平均值。

虽然 SQL 仍然是一种语法严格的语言,但我们只有经过一定的学习才能写出正确的语句。不过,如果我们不关心计算过程的话,还是会省下不少功夫的。

让我们看另一个例子。确定贡献销售额前半部分的主要客户。如果我们设计计算过程的话,会是这样的:

  1. 计算所有客户的总销售收入。

  2. 按销售收入倒序对客户进行排序,大客户排在前,小客户排在最后。

  3. 按此顺序从 0 开始累加每个客户的销售收入,超过总销售收入的一半时停止。那么遍历到的客户就是目标客户。

那么,用 SQL 写出来是什么样的呢?这是我能想到的最简单的方法:

原文地址:https://www.toymoban.com/diary/sql/603.html

如若转载,请注明出处:如若内容造成侵权 / 违法违规 / 事实不符,请联系站长进行投诉反馈,一经查实,立即删除!

    正文完
     0
    Yojack
    版权声明:本篇文章由 Yojack 于1970-01-01发表,共计2660字。
    转载说明:
    1 本网站名称:优杰开发笔记
    2 本站永久网址:https://yojack.cn
    3 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
    4 本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
    5 本站所有内容均可转载及分享, 但请注明出处
    6 我们始终尊重原创作者的版权,所有文章在发布时,均尽可能注明出处与作者。
    7 站长邮箱:laylwenl@gmail.com
    评论(没有评论)