当前位置: 首页 > 面试题库 >

反引号和撇号之间的最大区别是什么?

郝冥夜
2023-03-14
问题内容

以下两个查询给出完全不同的结果的原因是什么?

MariaDB [mydatabase]> SELECT COUNT(DISTINCT(`price`)) FROM `products`; --Good
+--------------------------+
| COUNT(DISTINCT(`price`)) |
+--------------------------+
|                     2059 |
+--------------------------+
1 row in set (0.01 sec)

MariaDB [mydatabase]> SELECT COUNT(DISTINCT('price')) FROM `products`; --Bad
+--------------------------+
| COUNT(DISTINCT('price')) |
+--------------------------+
|                        1 |
+--------------------------+
1 row in set (0.01 sec)

我已经在Google周围搜索了反引号和撇号(又称为单引号)之间的区别,但是我找不到任何迹象表明为什么对于像上列这样的列名它们会有不同的解释。

难道实际上不是将后一个查询中的单引号字符串解释为列名,而是解释为任意字符串文字,可以说其为“ 1”吗?如果是这样,要找到任何有关撇号含义的页面并不容易。


问题答案:

“价格”(撇号或引号)是一个字符串。它永远不会改变,因此计数始终为1。

“价格”(背景知识)是指该列price。因此可能会超过1。

内括号无关。 COUNT(DISTINCT price)与您的标准版本相同。

  • SELECT COUNT(*) FROM tbl WHERE ... 是询问多少行的常用方法。
  • SELECT foo, COUNT(*) FROM tbl GROUP BY foo是一种常见的询问方式,每个值对应多少行foo
  • SELECT foo, COUNT(foo) FROM tbl GROUP BY foo与上述相同,但不计算中的行foo IS NULL

SELECT DISTINCT ... GROUP BY ...是胡说八道。使用DISTINCT或使用GROUP BY。



 类似资料:
  • 问题内容: 我知道在PHP中,双引号和单引号之间的唯一区别是字符串中变量的解释和转义符的处理。 在JavaScript中,我经常看到字符串中使用双引号。是否有特定原因,还是单引号与双引号完全相同? 问题答案: 您将希望使用单引号,而您希望双引号出现在字符串内(例如html属性),而不必对其进行转义,反之亦然。除此之外,没有任何区别。 但是,请注意,JSON(JavaScript对象表示法)仅支持双

  • 本文向大家介绍xml 撇号和引号,包括了xml 撇号和引号的使用技巧和注意事项,需要的朋友参考一下 示例 属性值可以用单引号或双引号出现。适当的字符必须转义。            

  • 问题内容: 我对以下代码行的语法感到困惑: 数据框对象由2列(“大脑”和“身体”)组成 当我打印x_values时,我得到这样的东西: 就dataframe对象的属性和方法而言,我知道pandas文档,但双括号语法使我感到困惑。 问题答案: 考虑一下: 来源DF: 选择一列-生成Pandas.Series: 选择DataFrame的子集-结果为DataFrame: 结论: 第二种方法允许我们从Da

  • 反勾号的区别是什么(")

  • 问题内容: Java中的单引号和双引号之间有区别吗? 问题答案: 对文字s 使用单引号,对文字s 使用双引号,如下所示: 不能以其他任何方式使用它们(例如,在Python中)。

  • 问题内容: 我以为还会有另一个问题,但我找不到。在使用PHP的MySQL中,我通常用反引号封装字段名,以掩盖任何保留的名称或字符。但是,我的一位同事指出,这也可以使用方括号来实现。排除反引号与SQL Server不兼容的事实(显然),有什么区别?我应该使用哪个? 问题答案: SQL Server / T-SQL使用方括号(以及MS Access),而MySQL使用反引号。 据我所知,可以在文档中露